This is a simple library that allows you to input tags into a field, outputting an array. There's the option to disable duplication, asynchronous loading of lists, control props, and much more.
You can use "tab", "enter", "," to complete tag. And up/down arrow to navigate on list (enter press on list complete tag). Press backspace (if input empty) or click on cross, to remove a tag.
import vueAutocomplete from "@venegrad/vue3-autocomplete"
export default {
components: {
vueAutocomplete
},
}
Css if needed:
@import '@venegrad/vue3-autocomplete/dist/venAutocomplete.css'
list
: (Array, ['John', 'Doe']), Default = empty, List of tags for autocomplete.disabledSymbols
: (String, "#!=&)(/"), Default = null, List in string of disabled symbols or letters.min
: (Number, 1), Default = 1, Minimum length for 1 tag.max
: (Number, 1), Default = 200, Maximum length for 1 tag.dublicates
: (Boolean, false), Default = false, Available of disable dublcate tags.placeholder
: (String, "Start typing"), Default = null, Placeholder for input tagv-model
: v-model value (Array, ['John', 'Doe']), Dynamic v-model value
All you need to do is attach a watch event to the v-model value, but if that's not enough for you, I've added a few more events.
@inputEvent
= return value of input field, when user typing or pasting something.@changed
= return value of v-model when inner array or v-model changed. Starts first time on components mount, and every time when v-model changed.@open
= return dropdown trigger, opened or closed.
<template>
<ven-autocomplete ref="ggauto" />
</template>
<script setup>
const ggauto = ref()
onMouted(() => {
ggauto.value.goOpen();
setTimeout(() => {
ggauto.value.goClose();
}, 5000)
})
</script>
<venAutocomplete
:list="list"
placeholder="Write something, and press ',' or 'enter' or 'tab'"
disabled-symbols="#!=&)(/"
:max="30"
:min="3"
:dublicates="true"
v-model="vvalue"
@inputEvent="inputEvent"
@changed="changed"
@opened="opened"
/>
- If my solution was helpful to you, please give me a star on Github or get my day better with:
- USDT TRC20:
TKXybH3YoFvT5h8bQFLdkDBtiXA65y7xaB
- USDT ERC20:
0xc3efeB4825E350eE5D6B032Aa1dE144B09B5bB0D