filter.vue 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. <template>
  2. <el-input v-model="query" placeholder="Please enter keyword" @input="onQueryChanged" />
  3. <el-tree-v2 ref="treeRef" :data="data" :props="props" :filter-method="filterMethod" :height="208" />
  4. </template>
  5. <script lang="ts" setup>
  6. import { ref } from 'vue'
  7. import type { ElTreeV2 } from 'element-plus'
  8. import type { TreeNode } from 'element-plus/es/components/tree-v2/src/types'
  9. interface Tree {
  10. id: string
  11. label: string
  12. children?: Tree[]
  13. }
  14. const getKey = (prefix: string, id: number) => {
  15. return `${prefix}-${id}`
  16. }
  17. const createData = (maxDeep: number, maxChildren: number, minNodesNumber: number, deep = 1, key = 'node'): Tree[] => {
  18. let id = 0
  19. return Array.from({ length: minNodesNumber })
  20. .fill(deep)
  21. .map(() => {
  22. const childrenNumber = deep === maxDeep ? 0 : Math.round(Math.random() * maxChildren)
  23. const nodeKey = getKey(key, ++id)
  24. return {
  25. id: nodeKey,
  26. label: nodeKey,
  27. children: childrenNumber ? createData(maxDeep, maxChildren, childrenNumber, deep + 1, nodeKey) : undefined,
  28. }
  29. })
  30. }
  31. const query = ref('')
  32. const treeRef = ref<InstanceType<typeof ElTreeV2>>()
  33. const data = createData(4, 30, 5)
  34. const props = {
  35. value: 'id',
  36. label: 'label',
  37. children: 'children',
  38. }
  39. const onQueryChanged = (query: string) => {
  40. // TODO: fix typing when refactor tree-v2
  41. // eslint-disable-next-line @typescript-eslint/ban-ts-comment
  42. // @ts-expect-error
  43. treeRef.value!.filter(query)
  44. }
  45. const filterMethod = (query: string, node: TreeNode) => {
  46. return node.label!.includes(query)
  47. }
  48. </script>