Research
Security News
Malicious npm Package Targets Solana Developers and Hijacks Funds
A malicious npm package targets Solana developers, rerouting funds in 2% of transactions to a hardcoded address.
vue-simple-suggest
Advanced tools
Feature-rich autocomplete component for Vue.js
npm install --save vue-simple-suggest
This is a simple yet feature-rich suggestion/autocomplete component for Vue.js.
It supports v-model, allows custom styling, custom input and suggestion list templates, API calls and more.
All of the props, events and slots are OPTIONAL for this component, so it can be used without any configuration at all.
# clone the repo
git clone https://github.com/KazanExpress/vue-simple-suggest.git
cd ./vue-simple-suggest
# install dependencies
npm install
# serve example with hot reload at localhost
npm run dev
# build example for static serving
npm run build
Key | Description |
---|---|
Escape | If the suggestions list is shown - hide it. |
ArrowDown | If the suggestions list is hidden - show it. |
ArrowUp /ArrowDown | Cycle (hover) through suggestions. |
Enter | If the list is shown - chooses the highlighted element, if the list is hidden - refills the suggestions based on current input text. |
Ctrl + Space /Cmd + Space | Select the first element in the list. |
<!-- Ref to access the API, v-model for efficient query binding -->
<vue-simple-suggest ref="vueSimpleSuggest" v-model="model"
valueAttribute="id"
displayAttribute="title"
:placeholder="placeholder!!!"
:get-list="getListFunction"
:max-count="10"
:min-length="3"
:debounce="100"
:destyled="false"
:removeList="false"
:filter-by-query="false"
:value="defaultValue"
@input="onInputEvent"
@select="onSuggestSelect"
@hover="onSuggestHover"
@focus="onFocus"
@blur="onBlur"
@request-start="onRequestStart"
@request-done="onRequestDone"
@request-failed="onRequestFailed"
@show-list="onShowList"
@hide-list="onHideList"
>
<!-- v-model on input itself is useless -->
<input class="optional-custom-input">
<!-- Appears o top of the list -->
<template slot="miscItem-above" slot-scope="{ suggestions, query }">
<div class="misc-item">
<span>You're searching for {{ query }}.</span>
</div>
<div class="misc-item">
<span>{{ suggestions.length }} suggestions are shown...</span>
</div>
<hr>
</template>
<div slot="suggestionItem" slot-scope="{ suggestion }" class="custom">{{ suggestion.title }}</div>
<!-- Appears below the list -->
<div class="misc-item" slot="miscItem-below" slot-scope="{ suggestions }" v-if="loading">
<span>Loading...</span>
</div>
</vue-simple-suggest>
Name | Type | Default | Description |
---|---|---|---|
maxSuggestions | Number | 10 | The maximum amount of suggestions to display. Set to 0 for infinite suggestions. |
displayAttribute | String | 'title' | The property in a suggestion object to display in a list. Supports dotted paths. |
valueAttribute | String | 'id' | The property in a suggestion object to use as a unique key. Supports dotted paths. |
getList | Funciton or Array | () => [] | The array provider function, must accept a query as its only argument. Can return an array or a promise. Can be async. The component behaves as a simple input without this function. |
debounce | Number | 0 | Determines the getList debounce (a time between the input event and a function execution). |
destyled | Boolean | false | Whether to cancel the default styling of input and suggestions list. |
removeList | Boolean | false | If true - the suggestion list will be always hidden. |
filterByQuery | Boolean | false | Whether to filter the resulting suggestions by input's text query (make it a search component). |
type, value, pattern, etc... | All of the HTML5 input attributes with their respected default values. |
Name | Arguments | Description |
---|---|---|
input | HTML input event | An outward projection of the current input's event. |
focus | HTML focus event | An outward projection of the current input's event. |
blur | HTML focus event | An outward projection of the current input's event. |
select | Selected suggestion | Fires on suggestion selection (via a mouse click or enter keypress). |
hover | Hovered suggestion | Fires each time a new suggestion is highlighted (via a cursor movement or keyboard arrows). |
showList | - | Fires each time the suggestion list is toggled to be shown. |
hideList | - | Fires each time the suggestion list is being hidden. |
requestStart | Current input value (query) | Fires each time a getList function starts executing. |
requestDone | Resulting suggestions list | Fires when a getList function successfully returns a result and forwards that result as an argument. |
requestFailed | The interrrupting exception | Fires if an exception occurs during the execution of a getList funciton. |
accessed via
$refs.*your ref name here*
Name | Arguments | Description |
---|---|---|
showList | - | Shows the suggestion list. |
hideList | - | Hides the suggestion list. |
getSuggestions | query : string | Gets and processes suggestions from the list prop. Returns a promise. |
research | - | Debounced getSuggestions on the current input value. |
clearSuggestions | - | Clears the suggestions array. |
select | item | Selects the passed item. |
hover | item | Hovers over the passed item. |
accessed via
$refs.*your ref name here*
Name | Default | Description |
---|---|---|
selected | null | Currently selected element. |
hovered | null | Currently hovered element. |
suggestions | [] | Current suggestions list. |
listShown | false | Is suggestion list shown. |
inputElement | null | Currently used HTMLInputElement. |
canSend | true | Whether the assigned getListFuncion can be executed. |
timeoutInstance | null | The timeout until next getListFunction execution. |
text | vueSimpleSuggest.$props.value | Current input text. |
slotIsComponent | - | Whether this current custom input is a vue-component. |
listIsRequest | - | Whether the list prop is a function. |
input | - | A ref to the current input (component or vanilla). |
hoveredIndex | - | The current hovered element index. |
all optional
default slot
Supports nesting. Input props can be passed to a custom input to avoid their processing by vue-simple-suggest. Defaults to a simple input with props passed to vue-simple-suggest.
Warning: v-model
on a custom input IS NOT the same as v-model
on vue-simple-suggest!
<!-- Default HTMLInputElement example: -->
<vue-simple-suggest v-model="model" placeholder="Text here" type="search" pattern="[a-z]+"/>
<!-- Vanilla HTMLInputElement example 1: -->
<vue-simple-suggest>
<input pattern="[a-z]+">
</vue-simple-suggest>
<!-- Vanilla HTMLInputElement example 2: -->
<vue-simple-suggest v-model="model" placeholder="Text here" type="search">
</vue-simple-suggest>
<!-- Vanilla HTMLInputElement example 3 (fully equivalent to the second example): -->
<vue-simple-suggest v-model="model">
<input placeholder="Text here" type="search">
</vue-simple-suggest>
<!-- Vanilla HTMLInputElement example 4 (nested): -->
<vue-simple-suggest>
<div>
<section>
<input type="email">
</section>
</div>
</vue-simple-suggest>
<!-- Vue component example (also supports nesting): -->
<vue-simple-suggest>
<my-custom-input-somponent></my-custom-input-somponent>
</vue-simple-suggest>
suggestionItem
slot
Allows custom html-definitons of the suggestion items in a list.
Defaults to <span>{{ suggestion[displayAttribute] }}</span>
<!-- Example: -->
<vue-simple-suggest>
<div slot="suggestionItem" slot-scope="{ suggestion }">
<div>My {{ suggestion.title }}</div>
</div>
</vue-simple-suggest>
miscItem-above
andmiscItem-below
slots
Allow custom elements to be shown in suggestion list. These elements never dissapear from the list, niether can they be selected nor hovered on.
These can be used for decoration, loaders, error messages and etc.
Do not have defaults, so are not shown until defined.
Accept the suggestions
array and a query
text as a slot-scope
attribute values.
<!-- Examples: -->
<vue-simple-suggest>
<template slot="miscItem-above" slot-scope="{ suggestions, query }">
<div class="misc-item">
<span>You're searching for {{ query }}.</span>
</div>
<div class="misc-item">
<span>{{ suggestions.length }} suggestions are shown...</span>
</div>
</template>
<div slot="miscItem-below" slot-scope="{ suggestions }" v-if="isLoading" class="misc-item">
<span>Loading...</span>
</div>
</vue-simple-suggest>
FAQs
Feature-rich autocomplete component for Vue.js
The npm package vue-simple-suggest receives a total of 6,643 weekly downloads. As such, vue-simple-suggest popularity was classified as popular.
We found that vue-simple-suggest demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 4 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Research
Security News
A malicious npm package targets Solana developers, rerouting funds in 2% of transactions to a hardcoded address.
Security News
Research
Socket researchers have discovered malicious npm packages targeting crypto developers, stealing credentials and wallet data using spyware delivered through typosquats of popular cryptographic libraries.
Security News
Socket's package search now displays weekly downloads for npm packages, helping developers quickly assess popularity and make more informed decisions.