亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

vue封裝tree組件實現搜索功能

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

我使用的是 vue2 + antd, 那么 antd 的 tree 組件中沒有給我們封裝搜索,其官網提供的搜索也不是封裝好的,而且限制比較大,因為我的樹形進來要默認展開,官方的代碼是進行了響應式,就不能上來就全部展開了

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

那我們自己來根據這個思路,進行一下改裝, 首先看一下最終呈現是啥樣的:

如上圖,可以看到我們剛進來的時候,就默認是全部展開的,然后上面有一個搜索框,這里我們可以自己定義交互,可以綁定成搜索的回車事件,也可以綁定change事件, 思路就是當我們搜索以后,重置我們下面 tree 樹形的 輸入數據 data,這樣就簡單的實現了搜索以后顯示指定的樹形。

這里面復雜的地方在于那個遞歸,因為遞歸的時候我們需要得到 1、 一個新數據 2、搜索子級的時候也要全部的父級 3、 搜索父級的時候也要全部的子級,下面來看看代碼

首先是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 />

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

接下來看我們的業務代碼

<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)) {  // 如果當前節點符合條件,則將其復制到新的樹形結構中,并根據 includeChildren 參數決定是否將其所有子節點也復制到新的樹形結構中  newTree.push({ ...node, children: includeChildren ? this.searchTree(node.children || [], "", true) : [] })} else if (node.children) {  // 如果當前節點不符合條件且存在子節點,則遞歸遍歷子節點,以繼續搜索  const result = this.searchTree(node.children, keyword, true)  if (result.length > 0) {    // 如果子節點中存在符合條件的節點,則將其復制到新的樹形結構中    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 , 因為我們后期要更改數據,所以不能直接使用,要接一下, 在用戶輸入的時候,重置數據即可, 主要依賴于 searchTree 這個遞歸的方法,第三個參數是一個布爾值, 默認是 false ,當搜索到符合條件的父級節點時,除了將該節點復制到新的樹形結構中,還會根據 includeChildren 參數決定是否將其所有子節點也復制到新的樹形結構中。如果 includeChildren 參數為 true,則遞歸遍歷其所有子節點,并將其復制到新的樹形結構中。如果 includeChildren 參數為 false,則不會遞歸遍歷其子節點,只會將符合條件的父節點復制到新的樹形結構中。

最終在我們搜索的時候可以呈現以下效果:

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

到此這篇關于vue封裝tree組件實現搜索功能的文章就介紹到這了,更多相關vue tree搜索內容請搜索以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持!

標簽: JavaScript
主站蜘蛛池模板: 精品综合久久久久久97超人 | 麻豆网站在线免费观看 | 亚洲一区二区三区高清 | 国产大学生自拍视频 | 日韩一区二区在线视频 | 毛片基地免费 | 一级黄片一级毛片 | 国产成人亚洲精品大帝 | 国产视频 一区二区 | 色草视频 | 一级女性黄 色生活片 | 香蕉超级碰碰碰97视频在线观看 | 精品国产成人在线 | 亚洲欧美日本综合一区二区三区 | 女性一级全黄生活片 | 欧美日韩久久中文字幕 | 亚洲 欧美 另类 综合 日韩 | 日韩视频高清免费看 | 播放中国女人毛片一级带 | 网友自拍视频在线观看 | 国产欧美日韩另类 | 久久精品国产国产精品四凭 | 大学生久久香蕉国产线观看 | 亚洲国产精品一区二区久久 | 麻豆成人在线观看 | 黄色一级片免费在线观看 | jizzjizz日本护士 | 91高清免费国产自产拍2021 | 黄网站在线观看高清免费 | 亚洲限制级 | 国产精品成人h片在线 | 黄色在线观看视频免费 | 男人粗大一出一进女人下面视频 | 国产群p视频 | 成年人激情网 | 国语性猛交xxxx乱大交 | 亚洲一级片 | 亚洲地址一地址二地址三 | 日韩中文字幕精品久久 | 国产欧美日韩一区二区三区 | 国产成人一区二区三区视频免费 |