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

JavaScript平鋪數(shù)組轉(zhuǎn)樹形結(jié)構(gòu)的實現(xiàn)示例

 更新時間:2021年07月30日 09:58:07   作者:MikiMiki  
本文主要介紹了JavaScript平鋪數(shù)組轉(zhuǎn)樹形結(jié)構(gòu)的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

后臺丟來了1w條數(shù)據(jù)

千算萬算,還是沒有逃過,后臺真的就上萬條數(shù)據(jù)一次丟給前端了。好吧,好在還不是10w條。如下,后臺返回的是這樣的結(jié)構(gòu):

const flatArr = [
  { id: '001', name: '節(jié)點1' },
  { id: '0011', parentId: '001', name: '節(jié)點1-1' },
  { id: '00111', parentId: '0011', name: '節(jié)點1-1-1' },
  { id: '002', name: '節(jié)點2' },
]

可以看到,這實際上就是一個平鋪的數(shù)組,我們的需求是,要將這樣數(shù)據(jù)渲染在Element-ui的級聯(lián)選擇器中,他接收的是如下的樹形結(jié)構(gòu):

let options = [
  {
    value: 'zhinan',
    label: '指南',
    children: [
      {
        value: 'shejiyuanze',
        label: '設(shè)計原則',
        children: [
          { value: 'yizhi', label: '一致' },
          { value: 'fankui', label: '反饋'}
        ],
      }
    ]
  }
]

好家伙,這不就是需要我將平鋪數(shù)組轉(zhuǎn)成樹形結(jié)構(gòu)嘛!
一頓操作猛如虎,二話不說寫遞歸。

遞歸方式

大功告成,代碼簡潔,思路清晰,一運行,what?頁面卡死了,console.time() 計算,大概使用了18s才計算出我們需要的樹形結(jié)構(gòu)。
我反省了下我自己,這可是上萬條數(shù)據(jù),每次從下往上遞歸尋找父節(jié)點的子節(jié)點時都需要遍歷一次數(shù)組,這當(dāng)然耗時了!而且計算時長已經(jīng)明顯導(dǎo)致了頁面卡頓,此法肯定是不可取的,那么,有沒有更好的方案呢?

非遞歸方式

這里巧妙的應(yīng)用了對象保存的是引用的特點,每次將當(dāng)前節(jié)點的 id 作為 key,保存對應(yīng)節(jié)點的引用信息,遍歷數(shù)組時,每次更新 objMap 的 children 信息,這樣 objMap中保留了所有節(jié)點極其子節(jié)點,最重要的是,我們只需要遍歷一遍數(shù)組,時間復(fù)雜度為O(n)。使用這種方式,計算時長只需要60ms!

總結(jié)

  • 遞歸方式:每次遞歸尋找當(dāng)前節(jié)點的子節(jié)點時都需要重新遍歷一遍數(shù)組,時間復(fù)雜度為 O(nlogn)
  • 非遞歸方式:從根節(jié)點往下尋找子節(jié)點,通過 Map 保存每個節(jié)點及其子節(jié)點的信息,子節(jié)點保存的是 Map 上的引用,每個節(jié)點的子節(jié)點都可以在 Map 中通過 id 找到,時間復(fù)雜度為 O(n)

我們來看一個對比圖:

通過上面時間復(fù)雜度隨數(shù)據(jù)量增大的走勢可以看出,當(dāng)數(shù)據(jù)越來越大時,遞歸算法的耗時將遠(yuǎn)遠(yuǎn)大于非遞歸算法。因此,當(dāng)數(shù)據(jù)量小時,使用遞歸算法有一定的優(yōu)勢,但是當(dāng)數(shù)據(jù)大到一定的程度時,遞歸的做法的劣勢將越來越明顯,使用非遞歸算法會快很多!

最后,不得不感慨一下,通過這個對比,我們也可以明顯的感受到算法的重要性,不同的實現(xiàn)方式,差異可以很大,這值得引起每一個 developer 對算法的重視!

到此這篇關(guān)于JavaScript平鋪數(shù)組轉(zhuǎn)樹形結(jié)構(gòu)的實現(xiàn)示例的文章就介紹到這了,更多相關(guān)JavaScript平鋪數(shù)組轉(zhuǎn)樹形結(jié)構(gòu)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Javascript自定義事件詳解

    Javascript自定義事件詳解

    這篇文章主要介紹了Javascript自定義事件,本質(zhì)就是觀察者模式,好處就是將綁定事件和觸發(fā)事件相互隔離開等等,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • js中promise如何取到[[PromiseResult]]問題

    js中promise如何取到[[PromiseResult]]問題

    這篇文章主要介紹了js中promise如何取到[[PromiseResult]]問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-05-05
  • javascript中setTimeout使用指南

    javascript中setTimeout使用指南

    本文給大家通過3個方法向大家展示了javascript中的setTimeout的使用,非常的簡單,有需要的小伙伴可以參考下。
    2015-07-07
  • JavaScript中各種編碼解碼函數(shù)的區(qū)別和注意事項

    JavaScript中各種編碼解碼函數(shù)的區(qū)別和注意事項

    JavaScript 中encodeURI,encodeURIComponent與escape的區(qū)別和注
    2010-08-08
  • Openlayers實現(xiàn)擴散的動態(tài)點(水紋效果)

    Openlayers實現(xiàn)擴散的動態(tài)點(水紋效果)

    這篇文章主要為大家詳細(xì)介紹了Openlayers實現(xiàn)擴散的動態(tài)點,水紋效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-08-08
  • JS ES新特性 擴展運算符介紹

    JS ES新特性 擴展運算符介紹

    這篇文章主要介紹了JS ES新特性 擴展運算符,下面文章圍繞ES新特性 擴展運算符的相關(guān)資料展開詳細(xì)內(nèi)容,需要的朋友可以參考一下,希望對大家有所幫助
    2021-12-12
  • JS如何使用剪貼板操作Clipboard API

    JS如何使用剪貼板操作Clipboard API

    瀏覽器允許JavaScript腳本讀寫剪貼板,自動復(fù)制或粘貼內(nèi)容。一般來說,腳本不應(yīng)該改動用戶的剪貼板,以免不符合用戶的預(yù)期。但是,有些時候這樣做確實能夠帶來方便,比如"一鍵復(fù)制"功能,用戶點擊一下按鈕,指定的內(nèi)容就自動進(jìn)入剪貼板。本文將介紹3種方法來實現(xiàn)。
    2021-05-05
  • Bootstrap datepicker日期選擇器插件使用詳解

    Bootstrap datepicker日期選擇器插件使用詳解

    這篇文章主要為大家詳細(xì)介紹了Bootstrap datepicker日期選擇器插件的使用方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • 解決IE下select標(biāo)簽innerHTML插入option的BUG(兼容IE,FF,Opera,Chrome,Safari)

    解決IE下select標(biāo)簽innerHTML插入option的BUG(兼容IE,FF,Opera,Chrome,Safa

    在ie下面使用innerHTML來插入option選項的話,ie會去掉前面的<option>,并拆分成多個節(jié)點,這樣會造成select的出錯
    2010-05-05
  • Bootstrap模態(tài)框(modal)垂直居中的實例代碼

    Bootstrap模態(tài)框(modal)垂直居中的實例代碼

    這篇文章主要介紹了Bootstrap模態(tài)框(modal)垂直居中的實例代碼,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-08-08

最新評論