123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293 |
- <template>
- <el-tree-select v-model="value" :data="data" filterable />
- <el-divider />
- filter method:
- <el-tree-select v-model="value" :data="data" :filter-method="filterMethod" filterable />
- <el-divider />
- filter node method:
- <el-tree-select v-model="value" :data="data" :filter-node-method="filterNodeMethod" filterable />
- </template>
- <script lang="ts" setup>
- import { ref } from 'vue'
- const value = ref()
- const sourceData = [
- {
- value: '1',
- label: 'Level one 1',
- children: [
- {
- value: '1-1',
- label: 'Level two 1-1',
- children: [
- {
- value: '1-1-1',
- label: 'Level three 1-1-1',
- },
- ],
- },
- ],
- },
- {
- value: '2',
- label: 'Level one 2',
- children: [
- {
- value: '2-1',
- label: 'Level two 2-1',
- children: [
- {
- value: '2-1-1',
- label: 'Level three 2-1-1',
- },
- ],
- },
- {
- value: '2-2',
- label: 'Level two 2-2',
- children: [
- {
- value: '2-2-1',
- label: 'Level three 2-2-1',
- },
- ],
- },
- ],
- },
- {
- value: '3',
- label: 'Level one 3',
- children: [
- {
- value: '3-1',
- label: 'Level two 3-1',
- children: [
- {
- value: '3-1-1',
- label: 'Level three 3-1-1',
- },
- ],
- },
- {
- value: '3-2',
- label: 'Level two 3-2',
- children: [
- {
- value: '3-2-1',
- label: 'Level three 3-2-1',
- },
- ],
- },
- ],
- },
- ]
- const data = ref(sourceData)
- const filterMethod = value => {
- data.value = [...sourceData].filter(item => item.label.includes(value))
- }
- const filterNodeMethod = (value, data) => data.label.includes(value)
- </script>
|