色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

vue封裝tree組件實(shí)現(xiàn)搜索功能

瀏覽:36日期:2022-06-09 14:32:57

我使用的是 vue2 + antd, 那么 antd 的 tree 組件中沒(méi)有給我們封裝搜索,其官網(wǎng)提供的搜索也不是封裝好的,而且限制比較大,因?yàn)槲业臉?shù)形進(jìn)來(lái)要默認(rèn)展開(kāi),官方的代碼是進(jìn)行了響應(yīng)式,就不能上來(lái)就全部展開(kāi)了

可以看一下,官方的代碼是這樣的,靈活性很低的還是

那我們自己來(lái)根據(jù)這個(gè)思路,進(jìn)行一下改裝, 首先看一下最終呈現(xiàn)是啥樣的:

如上圖,可以看到我們剛進(jìn)來(lái)的時(shí)候,就默認(rèn)是全部展開(kāi)的,然后上面有一個(gè)搜索框,這里我們可以自己定義交互,可以綁定成搜索的回車事件,也可以綁定change事件, 思路就是當(dāng)我們搜索以后,重置我們下面 tree 樹(shù)形的 輸入數(shù)據(jù) data,這樣就簡(jiǎn)單的實(shí)現(xiàn)了搜索以后顯示指定的樹(shù)形。

這里面復(fù)雜的地方在于那個(gè)遞歸,因?yàn)檫f歸的時(shí)候我們需要得到 1、 一個(gè)新數(shù)據(jù) 2、搜索子級(jí)的時(shí)候也要全部的父級(jí) 3、 搜索父級(jí)的時(shí)候也要全部的子級(jí),下面來(lái)看看代碼

首先是vue模板中的代碼

<a-input-search   placeholder="搜索"  @change="searchOrg"  :allowClear="true"  v-model="searchPerson"></a-input-search><a-tree ref="tree" @select="onSelect" :tree-data="currentTree" default-expand-all />

從這里可以看出來(lái),我們封裝的要比官方的輕量很多,ref 和 這里的邏輯是沒(méi)有涉及的,可以刪掉。

接下來(lái)看我們的業(yè)務(wù)代碼

<script>export default {  props: {    treeList: {      type: Array,      default: () => []    },  },  data() {    return {      searchPerson: "",      currentTree: this.treeList,    }  },  methods: {    searchTree(tree, keyword, includeChildren = false) {      const newTree = []      for (let i = 0; i < tree.length; i++) {const node = tree[i]if (node.title.includes(keyword)) {  // 如果當(dāng)前節(jié)點(diǎn)符合條件,則將其復(fù)制到新的樹(shù)形結(jié)構(gòu)中,并根據(jù) includeChildren 參數(shù)決定是否將其所有子節(jié)點(diǎn)也復(fù)制到新的樹(shù)形結(jié)構(gòu)中  newTree.push({ ...node, children: includeChildren ? this.searchTree(node.children || [], "", true) : [] })} else if (node.children) {  // 如果當(dāng)前節(jié)點(diǎn)不符合條件且存在子節(jié)點(diǎn),則遞歸遍歷子節(jié)點(diǎn),以繼續(xù)搜索  const result = this.searchTree(node.children, keyword, true)  if (result.length > 0) {    // 如果子節(jié)點(diǎn)中存在符合條件的節(jié)點(diǎn),則將其復(fù)制到新的樹(shù)形結(jié)構(gòu)中    newTree.push({ ...node, children: result })  }}      }      return newTree    },    searchOrg() {      this.currentTree = this.searchTree(this.treeList, this.searchPerson, true)    },    async onSelect(selectedKeys, info) {    },  }}</script>

這里我的 tree-data 使用的是父組件傳入的 props , 因?yàn)槲覀兒笃谝臄?shù)據(jù),所以不能直接使用,要接一下, 在用戶輸入的時(shí)候,重置數(shù)據(jù)即可, 主要依賴于 searchTree 這個(gè)遞歸的方法,第三個(gè)參數(shù)是一個(gè)布爾值, 默認(rèn)是 false ,當(dāng)搜索到符合條件的父級(jí)節(jié)點(diǎn)時(shí),除了將該節(jié)點(diǎn)復(fù)制到新的樹(shù)形結(jié)構(gòu)中,還會(huì)根據(jù) includeChildren 參數(shù)決定是否將其所有子節(jié)點(diǎn)也復(fù)制到新的樹(shù)形結(jié)構(gòu)中。如果 includeChildren 參數(shù)為 true,則遞歸遍歷其所有子節(jié)點(diǎn),并將其復(fù)制到新的樹(shù)形結(jié)構(gòu)中。如果 includeChildren 參數(shù)為 false,則不會(huì)遞歸遍歷其子節(jié)點(diǎn),只會(huì)將符合條件的父節(jié)點(diǎn)復(fù)制到新的樹(shù)形結(jié)構(gòu)中。

最終在我們搜索的時(shí)候可以呈現(xiàn)以下效果:

當(dāng)我們想從新獲取全部的時(shí)候,只需要情況輸入框即可,這樣我們的遞歸方法會(huì)把完整的樹(shù)形返回給我們~

到此這篇關(guān)于vue封裝tree組件實(shí)現(xiàn)搜索功能的文章就介紹到這了,更多相關(guān)vue tree搜索內(nèi)容請(qǐng)搜索以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持!

標(biāo)簽: JavaScript
主站蜘蛛池模板: 性欧美另类老妇高清 | 亚洲高清在线看 | 99久久国产综合精品1尤物 | 久久久综合久久 | 国产精品一区高清在线观看 | 久久久小视频 | 免费的成人a视频在线观看 免费的毛片 | 中文字幕亚洲一区二区v@在线 | 久久99精品这里精品3 | 亚洲精品国产第一区二区三区 | a级在线观看 | 国产年成美女网站视频免费看 | 99精品国产成人一区二区 | 久久精品国产欧美日韩99热 | 亚洲狠狠综合久久 | 日本欧美久久久久免费播放网 | 97在线碰碰观看免费高清 | 久久久久国产一级毛片高清板 | 日韩一级 | 美女张开腿让人桶 | 免费观看欧美一级片 | 91在线一区二区三区 | 免费观看a级网站 | 中国国产成人精品久久 | 国产成人久久久精品毛片 | 亚洲欧美日本视频 | 窝窝社区在线观看www | 亚洲激情黄色 | 91香蕉国产观看免费人人 | 国产综合成人久久大片91 | 俄罗斯一级毛片免费播放 | 美女18一级毛片免费看 | 精品在线观看免费 | 一级视频在线播放 | 91精品欧美一区二区综合在线 | 中文乱码字幕午夜无线观看 | 成人毛片免费免费 | 国产三级a | 极品美女户外勾搭无套 | 国产日韩久久久精品影院首页 | 美女扒开腿让男人桶爽免费动态图 |