Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

vue3-simple-typeahead

Package Overview
Dependencies
Maintainers
1
Versions
14
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

vue3-simple-typeahead

A simple and lightweight Vue3 typeahead component that show a suggested list of elements while the user types in.

  • 1.0.11
  • latest
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
4.8K
increased by67.23%
Maintainers
1
Weekly downloads
 
Created
Source

vue3-simple-typeahead

npm vue3 License npm npm bundle size

A Vue3 component for a simple typeahead component. It will show a list of suggested items based on the user input.

The component includes it's own input and when the user types on it the suggested options appear.

Demo

Demo

Go to demo page

vue3-simple-typeahead-demo source code

Installation

NPM

npm install vue3-simple-typeahead

Browser

You can also use the browser bundle in a script tag.

<script src="https://unpkg.com/vue3-simple-typeahead"></script>

Add installed component to your app

Import the vue3-simple-typeahead component and register it globally in your Vue app. Import the CSS as well if you wish to use the default styling.

import { createApp } from 'vue';
import App from './App.vue';
import SimpleTypeahead from 'vue3-simple-typeahead';
import 'vue3-simple-typeahead/dist/vue3-simple-typeahead.css'; //Optional default CSS

let app = createApp(App);
app.use(SimpleTypeahead);
app.mount('#app');

You can also import vue3-simple-typeahead locally in your component if you prefer.

import SimpleTypeahead from 'vue3-simple-typeahead';
import 'vue3-simple-typeahead/dist/vue3-simple-typeahead.css'; //Optional default CSS

export default {
	name: 'my-vue-component',
	components: {
		SimpleTypeahead,
	},
};

Usage

Use the component on your own app components

<vue3-simple-typeahead
	id="typeahead_id"
	placeholder="Start writing..."
	:items="['One','Two','Three']"
	:minInputLength="1"
	:itemProjection="itemProjectionFunction"
	@selectItem="selectItemEventHandler"
	@onInput="onInputEventHandler"
	@onFocus="onFocusEventHandler"
	@onBlur="onBlurEventHandler"
>
</vue3-simple-typeahead>

With custom slots template

<vue3-simple-typeahead
	id="typeahead_id"
	placeholder="Start writing..."
	:items="['One','Two','Three']"
	:minInputLength="1"
	:itemProjection="itemProjectionFunction"
	@selectItem="selectItemEventHandler"
	@onInput="onInputEventHandler"
	@onFocus="onFocusEventHandler"
	@onBlur="onBlurEventHandler"
>
	<template #list-header>
		LIST HEADER
	</template>
	<template #list-item-text="slot"><span v-html="slot.boldMatchText(slot.itemProjection(slot.item))"></span></template>
	<template #list-footer>
		LIST FOOTER
	</template>
</vue3-simple-typeahead>

User interaction

When the user types on the typeahead input and the minimum input length is meeted a suggestion list appears below the input with the items that match the user input. You can continue to type further to filter the selection, but you could use keyboard or mouse input to make your selection.abnf

When the suggestion list show up, you can continue to type to filter the selection or you use the Arrow Up or Arrow Down keys to navigate the list of suggestions. When you have selected the desired element press Enter or TAB to select the current element.

ControlEffect
Navigate up on the suggestion list, selecting the previous element
Navigate down on the suggestion list, selecting the next element
EnterChoose the current element selection
TABChoose the current element selection (if selectOnTab is true)

You can use the mouse instead, simply hover you cursor over the desire element and click on it.

User controls

Fallthrough attributes

All attributes added to the component not provided by props fallthrough the input control. For example if you added the disabled attribute:

<vue3-simple-typeahead
	id="typeahead_id"
	placeholder="Start writing..."
	:items="['One','Two','Three']"
	:minInputLength="1"
	:itemProjection="itemProjectionFunction"
	@selectItem="selectItemEventHandler"
	@onInput="onInputEventHandler"
	@onFocus="onFocusEventHandler"
	@onBlur="onBlurEventHandler"
	:disabled="disabled"
>
</vue3-simple-typeahead>

It would fallthrough to the input control of the component:

<!---->
<input [...] :disabled="disabled" />
<!---->

Props

PropTypeDefaultDescription
idStringRandom id generationThe id for the input control. Can be useful to link with a label for=""
placeholderString''Placeholder text for the input
itemsArray (Required)List of objects or strings with the elements for suggestions
defaultItemAnyDefault item to be selected
minInputLengthNumber2Minimum input length for the suggestion length to appear, the prop value has to be >= 0
minItemLengthNumber0Minimum number of items that need to be visible for suggestions to appear, the prop value has to be >= 0
itemProjectionFunction: String(item) => {return item;}Projection function to map the items to a string value for search and display
selectOnTabBooleantrueEnable/Disable item selection on TAB

Remember you can always use lower-kebap-case for camelCase props like min-input-length

Events

EventSignatureDescription
selectItemfunction (item: String): voidEmitted when the user selects an item from the suggestion list
onInputfunction (event: Object { input: String, items: Array }): voidEmitted when the user types anything
onFocusfunction (event: Object { input: String, items: Array }): voidEmitted when the input control get the focus
onBlurfunction (event: Object { input: String, items: Array }): voidEmitted when the input control lost the focus [When the user select an item, the focus is lost too]

Slots

SlotParentPropsDescription
#list-headerdiv.simple-typeahead-list-headerSlot to be show at top of the suggestion list
#list-item-textspan.simple-typeahead-list-item-text'item, itemProjection, boldMatchTextSlot to customize the text of every item in the suggestion list
#list-footerdiv.simple-typeahead-list-footerSlot to be show at bottom of the suggestion list
Slot #list-item-text props
PropTypeDescription
itemString or ObjectThe item of the items array
itemProjectionfunctionUse the item projection function provided as prop to the vue3-simple-typeahead element
boldMatchTextfunctionA function that receives a string and add strong tags to the parts of the text matched by the search criteria

Methods

MethodSignatureDescription
clearInputfunction (): voidClean the input with an empty string ''
focusInputfunction (): voidTrigger focus on the input and called onFocus event handler
blurInputfunction (): voidTrigger blur on the input and called onBlur event handler
getInputfunction (): HTMLInputElementReturn the HTMLInputElement corresponding to the input control

This methods are accesible via refs

<vue3-simple-typeahead ref="inputRef"> </vue3-simple-typeahead>
{
	this.$refs.inputRef;
}

Styling

Overwrite styles when using the default css included or add custom styles basing your rules on this structure.

div#{:id}_wrapper.simple-typeahead
    input#{:id}.simple-typeahead-input
    div.simple-typeahead-list
        .simple-typeahead-list-header
        .simple-typeahead-list-item &.simple-typeahead-list-item-active
            .simple-typeahead-list-item-text
        .simple-typeahead-list-footer

Keywords

FAQs

Package last updated on 10 Sep 2022

Did you know?

Socket

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.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc