您好,登錄后才能下訂單哦!
本篇文章和大家了解一下如何通過vue封裝tree組件實現(xiàn)搜索功能。有一定的參考價值,有需要的朋友可以參考一下,希望對大家有所幫助。
我使用的是 vue2 + antd, 那么 antd 的 tree 組件中沒有給我們封裝搜索,其官網(wǎng)提供的搜索也不是封裝好的,而且限制比較大,因為我的樹形進來要默認展開,官方的代碼是進行了響應式,就不能上來就全部展開了
可以看一下,官方的代碼是這樣的,靈活性很低的還是
那我們自己來根據(jù)這個思路,進行一下改裝, 首先看一下最終呈現(xiàn)是啥樣的:
如上圖,可以看到我們剛進來的時候,就默認是全部展開的,然后上面有一個搜索框,這里我們可以自己定義交互,可以綁定成搜索的回車事件,也可以綁定change
事件, 思路就是當我們搜索以后,重置我們下面 tree
樹形的 輸入數(shù)據(jù) data
,這樣就簡單的實現(xiàn)了搜索以后顯示指定的樹形。
這里面復雜的地方在于那個遞歸,因為遞歸的時候我們需要得到 1、 一個新數(shù)據(jù) 2、搜索子級的時候也要全部的父級 3、 搜索父級的時候也要全部的子級,下面來看看代碼
首先是vue模板中的代碼
<a-input-search placeholder="搜索" @change="searchOrg" :allowClear="true" v-model="searchPerson" ></a-input-search> <a-tree class="tree_box" ref="tree" @select="onSelect" :tree-data="currentTree" default-expand-all />
從這里可以看出來,我們封裝的要比官方的輕量很多,ref
和 這里的邏輯是沒有涉及的,可以刪掉。
接下來看我們的業(yè)務代碼
<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)) { // 如果當前節(jié)點符合條件,則將其復制到新的樹形結構中,并根據(jù) includeChildren 參數(shù)決定是否將其所有子節(jié)點也復制到新的樹形結構中 newTree.push({ ...node, children: includeChildren ? this.searchTree(node.children || [], '', true) : [] }) } else if (node.children) { // 如果當前節(jié)點不符合條件且存在子節(jié)點,則遞歸遍歷子節(jié)點,以繼續(xù)搜索 const result = this.searchTree(node.children, keyword, true) if (result.length > 0) { // 如果子節(jié)點中存在符合條件的節(jié)點,則將其復制到新的樹形結構中 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
, 因為我們后期要更改數(shù)據(jù),所以不能直接使用,要接一下, 在用戶輸入的時候,重置數(shù)據(jù)即可, 主要依賴于 searchTree
這個遞歸的方法,第三個參數(shù)是一個布爾值, 默認是 false
,當搜索到符合條件的父級節(jié)點時,除了將該節(jié)點復制到新的樹形結構中,還會根據(jù) includeChildren
參數(shù)決定是否將其所有子節(jié)點也復制到新的樹形結構中。如果 includeChildren
參數(shù)為 true
,則遞歸遍歷其所有子節(jié)點,并將其復制到新的樹形結構中。如果 includeChildren
參數(shù)為 false
,則不會遞歸遍歷其子節(jié)點,只會將符合條件的父節(jié)點復制到新的樹形結構中。
最終在我們搜索的時候可以呈現(xiàn)以下效果:
當我們想從新獲取全部的時候,只需要情況輸入框即可,這樣我們的遞歸方法會把完整的樹形返回給我們~
Vue是一套用于構建用戶界面的漸進式JavaScript框架,Vue與其它大型框架的區(qū)別是,使用Vue可以自底向上逐層應用,其核心庫只關注視圖層,方便與第三方庫和項目整合,且使用Vue可以采用單文件組件和Vue生態(tài)系統(tǒng)支持的庫開發(fā)復雜的單頁應用。
以上就是如何通過vue封裝tree組件實現(xiàn)搜索功能的簡略介紹,當然詳細使用上面的不同還得要大家自己使用過才領會。如果想了解更多,歡迎關注億速云行業(yè)資訊頻道哦!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。