Package Exports
- vue-simple-suggest
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (vue-simple-suggest) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
vue-simple-suggest
Simple yet feature-rich autocomplete component for Vue.js
npm install --save vue-simple-suggestTable of contents
What is it
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.
Actually, it's so feature rich, that it's possible to do crazy stuff with it, like
- Imitating drop-downs and drop-down menus
- Turn suggestions list into an actual suggestions table
- Work with ANY type of custom input passed (like type=button, radio and etc.)
- ... And many more things
And, as a bonus, it is very light (<4kb minified).
All of the props, events and slots are OPTIONAL for this component, so it can be used without any configuration at all.
Simple example
To use the component just install via NPM:
npm install --save vue-simple-suggest
Then, in your Vue.js component/page:
<!-- Some component.vue -->
<template>
<vue-suggest
v-model="chosen"
:list="simpleSuggestionList"
></vue-suggest>
<br>
<p>Chosen element: {{ chosen }}</p>
</template>
<script>
import VueSuggest from 'vue-simple-suggest'
export default {
components: {
VueSuggest
},
data() {
return {
chosen: ''
}
},
methods: {
simpleSuggestionList() {
return [
'Vue.js',
'React.js',
'Angular.js'
]
}
}
}
</script>Build Setup
# 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 & readme for static serving
npm run docsDefault Controls
These are default keyboard shortcuts.
Can be customized with the controls prop. All fields in this controls object are optional.
Default scheme:
| Key (key code) | Description |
|---|---|
Escape (27) |
If the suggestions list is shown - hide it. Defined by hideList property. |
ArrowDown (40) |
If the suggestions list is hidden - show it. Defined by selectionDown property. |
ArrowUp (38) / ArrowDown (40) |
Cycle (hover) through suggestions. Defined by selectionUp/selectionDown properties respectfully. |
Enter (13) |
If the list is shown - chooses the highlighted element, if the list is hidden - refills the suggestions based on current input text. Defined by select property. |
(Ctrl/Shift) + Space (32) |
Select the first element in the list. Defined by autocomplete property. Works with Ctrl modifier key or Shift modifier key. |
(Ctrl/Shift) + Enter (13) |
Same as previous, but also hides the suggestions list. |
JS object:
{
selectionUp: [38],
selectionDown: [40],
select: [13],
hideList: [27],
autocomplete: [32, 13]
}Component API
TLDR
<!-- Ref to access the API, v-model for efficient query binding -->
<vue-simple-suggest ref="vueSimpleSuggest" v-model="model"
value-attribute="id"
display-attribute="title"
:placeholder="placeholder!!!"
:list="getListFunction"
:max-count="10"
:min-length="3"
:debounce="100"
:destyled="false"
:remove-list="false"
:filter-by-query="false"
:value="defaultValue"
:controls="{
selectionUp: [38, 33],
selectionDown: [40, 34],
select: [13, 36],
hideList: [27, 35],
autocomplete: [32, 13],
}"
@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>API definitions
Props
| Name | Type | Default | Description |
|---|---|---|---|
controls |
Object | See default controls | Determines the keyboard shortcuts in key-codes (for browser-compatibility purposes). Arrays provide the ability to assign multiple keys to one action. Consists of 5 array fields: selectionUp, selectionDown, select, hideList and autocomplete, all of which are optional. |
max-suggestions |
Number | 10 |
The maximum amount of suggestions to display. Set to 0 for infinite suggestions. |
display-attribute |
String | 'title' |
The property in a suggestion object to display in a list. Supports dotted paths. |
value-attribute |
String | 'id' |
The property in a suggestion object to use as a unique key. Supports dotted paths. |
list |
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 list 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. |
remove-list |
Boolean | false |
If true - the suggestion list will be always hidden. |
filter-by-query |
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. |
Emitted Events
| 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). |
show-list |
- | Fires each time the suggestion list is toggled to be shown. |
hide-list |
- | Fires each time the suggestion list is being hidden. |
request-start |
Current input value (query) | Fires each time a list function starts executing. |
request-done |
Resulting suggestions list | Fires when a list function successfully returns a result and forwards that result as an argument. |
request-failed |
The interrrupting exception | Fires if an exception occurs during the execution of a list funciton. |
Ref Methods
accessed via
$refs.*your ref name here*
| Name | Arguments | Description |
|---|---|---|
showList |
- | Shows the suggestion list. Emits the respected event. |
hideList |
- | Hides the suggestion list. Emits the respected event. |
getSuggestions |
query: string |
Gets and processes suggestions from the list prop. Returns a promise. Emits the requestStart, requestDone and requestFailed events. |
research |
- | Debounced getSuggestions on the current input value. |
clearSuggestions |
- | Clears the suggestions array. |
select |
suggestion | Selects the passed suggestion. Emits the respected event. |
hover |
suggestion | Hovers over the passed suggestion. Emits the respected event. |
displayProperty |
suggestion | Returns the displayed property of a suggestion. |
valueProperty |
suggestion | Returns the value property of a suggestion. |
Ref Event Handlers
accessed via
$refs.*your ref name here*
You can use these to imitate come of the component's behaviours.
| Name | Arguments | Description |
|---|---|---|
onInputClick |
HTML click event | Fires whenever the input is being clicked. |
onInput |
HTML input event | Fires whenever the input text is changed. Emits the input event. |
onFocus |
HTML focus event | Fires whenever the input comes into focus, emits the focus event. |
onBlur |
HTML focus event | Antonym to onFocus. |
onAutocomplete |
- | Fires when the autocomplete keyboard shortcut is pressed. Selects the first suggestion. |
onListKeyUp |
HTML keyup event | Fires on component keyup. Internally used for hiding the list. |
onArrowKeyDown |
HTML keydown event | Fires on component keydown. Internally used for arrow-key-based selections. |
Ref Data
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. |
controlScheme |
Default Controls | The current controls scheme. |
Slots
all optional
Custom input
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>Custom suggestion item
suggestionItemslot
Allows custom html-definitons of the suggestion items in a list.
Defaults to <span>{{ displayAttribute(suggestion) }}</span>
Accepts the suggestion object and a query text as a slot-scope attribute values.
<!-- Example: -->
<vue-simple-suggest>
<div slot="suggestionItem" slot-scope="{ suggestion, query }">
<div>My {{ suggestion.title }}</div>
</div>
</vue-simple-suggest>In cooperation with ref fields can be used to drastically transform the suggestion list behaviour.
One of the simplest examples - highlighting the query text in the results:
<div slot="suggestionItem" slot-scope="scope">
<span v-html="boldenSuggestion(scope)"></span>
</div>boldenSuggestion({ suggestion, query }) {
let result = this.$refs.vueSimpleSuggest.displayProperty(suggestion);
if (!query) return result;
const replace = str => (result = result.replace(str, str.bold()));
const texts = query.split(/[\s-_/\\|\.]/gm).filter(t => !!t) || [''];
const processors = [
s => s[0].toUpperCase() + s.substr(1),
s => s.toLowerCase(),
s => s.toUpperCase(),
s => s
];
texts.forEach(text => processors.forEach(processor => replace(processor(text))));
return result;
}Result:

Custom miscellanious item slots
miscItem-aboveandmiscItem-belowslots
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>