91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何通過vue封裝tree組件實現搜索功能

發布時間:2023-06-09 09:17:48 來源:億速云 閱讀:351 作者:栢白 欄目:開發技術

本篇文章和大家了解一下如何通過vue封裝tree組件實現搜索功能。有一定的參考價值,有需要的朋友可以參考一下,希望對大家有所幫助。

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

如何通過vue封裝tree組件實現搜索功能

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

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

如何通過vue封裝tree組件實現搜索功能

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

這里面復雜的地方在于那個遞歸,因為遞歸的時候我們需要得到 1、 一個新數據 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 和 這里的邏輯是沒有涉及的,可以刪掉。

接下來看我們的業務代碼

<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是什么

Vue是一套用于構建用戶界面的漸進式JavaScript框架,Vue與其它大型框架的區別是,使用Vue可以自底向上逐層應用,其核心庫只關注視圖層,方便與第三方庫和項目整合,且使用Vue可以采用單文件組件和Vue生態系統支持的庫開發復雜的單頁應用。

以上就是如何通過vue封裝tree組件實現搜索功能的簡略介紹,當然詳細使用上面的不同還得要大家自己使用過才領會。如果想了解更多,歡迎關注億速云行業資訊頻道哦!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

正安县| 天津市| 三明市| 乌鲁木齐县| 施秉县| 波密县| 南澳县| 寻乌县| 车险| 麻江县| 濉溪县| 崇明县| 宁陵县| 固原市| 商水县| 阜平县| 江口县| 西青区| 修水县| 大邑县| 文安县| 华安县| 那曲县| 西藏| 通州区| 达州市| 轮台县| 富锦市| 孝昌县| 高唐县| 浦城县| 崇明县| 阳高县| 台北县| 新龙县| 资溪县| 五寨县| 德令哈市| 峨眉山市| 竹山县| 轮台县|