若想要在Vue中實(shí)現(xiàn)select組件,則需要進(jìn)行一系列的配置與編碼。其具體實(shí)現(xiàn)方式,可以通過以下的步驟進(jìn)行講解:
<template>
<div class="select-container">
<div class="select-inner">
<input :value="selected" v-model="search" v-on:click="toggleOptions">
<ul v-if="isOpen">
<li v-for="(option, index) in filteredOptions" :key="index"
v-on:click="selectOption(option)">
{{ option.name }}
</li>
</ul>
</div>
</div>
</template>
<script>
export default {
name: 'select',
props: {
options: Array,
selected: String,
},
data() {
return {
isOpen: false,
search: '',
};
},
computed: {
filteredOptions() {
return this.options.filter((option) =>option.name.toLowerCase().includes(this.search.toLowerCase()));
},
},
methods: {
toggleOptions() {
this.isOpen = !this.isOpen;
},
selectOption(option) {
this.$emit('select', option);
this.isOpen = false;
},
},
};
</script>
該代碼中的核心部分在于“template”標(biāo)簽內(nèi)的內(nèi)容。首先,需要指定select整體的容器。然后,將input和ul作為該容器的子元素。input的值即為被選中的value,該值可以通過v-model與search進(jìn)行雙向綁定。ul為下拉框,需要通過v-if判斷是否展示。其中l(wèi)i為下拉框中單個(gè)選項(xiàng),通過v-for進(jìn)行循環(huán)展示。
接下來需要對(duì)代碼進(jìn)行相關(guān)的解釋,便于在實(shí)際操作中的理解。
在props中,定義了options和selected,表示傳入該組件的選項(xiàng)和當(dāng)前選中的值。
在data中,定義了isOpen和search,表示下拉框是否展開和搜索框中的內(nèi)容。
在computed中,定義了filteredOptions,可以理解為對(duì)選項(xiàng)進(jìn)行篩選,展示符合搜索內(nèi)容的選項(xiàng)。
在methods中,定義了toggleOptions和selectOption,分別表示展開/收起下拉框和選中某個(gè)選項(xiàng)。當(dāng)選中某個(gè)選項(xiàng)后,需要通過$emit將該選項(xiàng)發(fā)送出去,并將下拉框收起。