欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2023年05月15日 10:27:19   作者:code_Bo  
本文主要介紹了vue封裝tree組件實(shí)現(xiàn)搜索功能,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

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

iShot_2023-05-09_18.57.35.png

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

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

iShot_2023-05-09_19.00.39.png

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

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

首先是vue模板中的代碼

<a-input-search
  style="margin-bottom: 2px"
  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è)務(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ù)制到新的樹形結(jié)構(gòu)中,并根據(jù) includeChildren 參數(shù)決定是否將其所有子節(jié)點(diǎn)也復(fù)制到新的樹形結(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ù)制到新的樹形結(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ù)制到新的樹形結(jié)構(gòu)中,還會(huì)根據(jù) includeChildren 參數(shù)決定是否將其所有子節(jié)點(diǎn)也復(fù)制到新的樹形結(jié)構(gòu)中。如果 includeChildren 參數(shù)為 true,則遞歸遍歷其所有子節(jié)點(diǎn),并將其復(fù)制到新的樹形結(jié)構(gòu)中。如果 includeChildren 參數(shù)為 false,則不會(huì)遞歸遍歷其子節(jié)點(diǎn),只會(huì)將符合條件的父節(jié)點(diǎn)復(fù)制到新的樹形結(jié)構(gòu)中。

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

iShot_2023-05-09_19.12.40.png

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

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

相關(guān)文章

  • Vue如何根據(jù)id在數(shù)組中取出數(shù)據(jù)

    Vue如何根據(jù)id在數(shù)組中取出數(shù)據(jù)

    這篇文章主要介紹了Vue如何根據(jù)id在數(shù)組中取出數(shù)據(jù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • Vue項(xiàng)目中使用mock.js的完整步驟

    Vue項(xiàng)目中使用mock.js的完整步驟

    這篇文章主要給大家介紹了關(guān)于在Vue項(xiàng)目中使用mock.js的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • Vue PostCSS的使用介紹

    Vue PostCSS的使用介紹

    postcss一種對(duì)css編譯的工具,類似babel對(duì)js的處理,postcss只是一個(gè)工具,本身不會(huì)對(duì)css一頓操作,它通過插件實(shí)現(xiàn)功能,autoprefixer就是其一
    2023-02-02
  • Vue3異步組件Suspense的使用方法詳解

    Vue3異步組件Suspense的使用方法詳解

    這篇文章主要介紹了Vue3異步組件Suspense的使用方法詳解,需要的朋友可以參考下
    2023-01-01
  • Vue2和Vue3的nextTick實(shí)現(xiàn)原理

    Vue2和Vue3的nextTick實(shí)現(xiàn)原理

    Vue 中的數(shù)據(jù)綁定和模板渲染都是異步的,那么如何在更新完成后執(zhí)行回調(diào)函數(shù)呢?這就需要用到 Vue 的 nextTick 方法了,本文詳細(xì)介紹了Vue2和Vue3的nextTick實(shí)現(xiàn)原理,感興趣的同學(xué)可以參考一下
    2023-04-04
  • 解決vue.js中settimeout遇到的問題(時(shí)間參數(shù)短效果不穩(wěn)定)

    解決vue.js中settimeout遇到的問題(時(shí)間參數(shù)短效果不穩(wěn)定)

    這篇文章主要介紹了解決vue.js中settimeout遇到的問題(時(shí)間參數(shù)短效果不穩(wěn)定),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • vue3.x使用swiperUI動(dòng)態(tài)加載圖片失敗的解決方法

    vue3.x使用swiperUI動(dòng)態(tài)加載圖片失敗的解決方法

    這篇文章主要為大家詳細(xì)介紹了vue3.x使用swiperUI動(dòng)態(tài)加載圖片失敗的解決方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • Vue項(xiàng)目利用axios請(qǐng)求接口下載excel

    Vue項(xiàng)目利用axios請(qǐng)求接口下載excel

    這篇文章主要為大家詳細(xì)介紹了Vue項(xiàng)目利用axios請(qǐng)求接口下載excel,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-11-11
  • Vue防止白屏添加首屏動(dòng)畫的實(shí)例

    Vue防止白屏添加首屏動(dòng)畫的實(shí)例

    今天小編就為大家分享一篇Vue防止白屏添加首屏動(dòng)畫的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-10-10
  • Vue2.4+新增屬性.sync、$attrs、$listeners的具體使用

    Vue2.4+新增屬性.sync、$attrs、$listeners的具體使用

    這篇文章主要介紹了Vue2.4+新增屬性.sync、$attrs、$listeners的具體使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-03-03

最新評(píng)論