真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

JavaScript如何實(shí)現(xiàn)無(wú)限級(jí)遞歸樹(shù)-創(chuàng)新互聯(lián)

JavaScript如何實(shí)現(xiàn)無(wú)限級(jí)遞歸樹(shù)?針對(duì)這個(gè)問(wèn)題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問(wèn)題的小伙伴找到更簡(jiǎn)單易行的方法。

成都創(chuàng)新互聯(lián)成立于2013年,先為香洲等服務(wù)建站,香洲等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢(xún)服務(wù)。為香洲企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問(wèn)題。

需求:最近遇到一個(gè)需求,平時(shí)被后臺(tái)慣著直接返回了樹(shù)形結(jié)構(gòu)給到前端,前端對(duì)這種嵌套類(lèi)型的數(shù)據(jù)(如地區(qū)的級(jí)聯(lián)或菜單的樹(shù)形結(jié)構(gòu))省掉了一層處理。換了個(gè)后臺(tái)開(kāi)發(fā)返回了扁平化的數(shù)組數(shù)據(jù)給到前端自己去處理如下data。突然有點(diǎn)慌......

const data = [
    {
        "area_id": 5,
        "name": "廣東省",
        "parent_id": 0,
    },  
    {
        "area_id": 6,
        "name": "廣州市",
        "parent_id": 5,
    },
    {
        "area_id": 7,
        "name": "深圳市",
        "parent_id": 5,
    },
    {
        "area_id": 4,
        "name": "北京市",
        "parent_id": 3,
    },
    {
        "area_id": 3,
        "name": "北京",
        "parent_id": 0,
    },
    {
        "area_id": 2,
        "name": "測(cè)試子地區(qū)",
        "parent_id": 1,
    },
    {
        "area_id": 1,
        "name": "測(cè)試地區(qū)",
        "parent_id": 0,
    }
]

emmm,換個(gè)念頭想想也剛好鍛煉鍛煉,擼起袖子干吧,然后就總結(jié)了以下兩種整理方法~

方法一——遞歸

在這種那么適合遞歸的場(chǎng)景,怎么能少了遞歸這個(gè)角色呢?第一種方法,遞歸出場(chǎng)!獻(xiàn)上遞歸寶器~

function toTreeData(data,pid){
 
    function tree(id) {
        let arr = []
        data.filter(item => {
            return item.parent_id === id;
        }).forEach(item => {
            arr.push({
                area_id: item.area_id,
                label: item.name,
                children: tree(item.area_id)
            })
        })
        return arr
    }
    return tree(pid)  // 第一級(jí)節(jié)點(diǎn)的父id,是null或者0,視情況傳入
}

恩,姿勢(shì)擺好,在控制臺(tái)里執(zhí)行一下

JavaScript如何實(shí)現(xiàn)無(wú)限級(jí)遞歸樹(shù)

哎喲,不錯(cuò)哦~后臺(tái)小哥哥再也不擔(dān)心需要返回什么數(shù)據(jù)給我了。不過(guò),該方法有個(gè)缺點(diǎn),在我使用組件的時(shí)候需要的數(shù)據(jù)結(jié)構(gòu)中,如果子級(jí)沒(méi)有數(shù)據(jù)children返回[]。恩,有點(diǎn)問(wèn)題,但是還是可以?xún)?yōu)化的,優(yōu)化的代碼我會(huì)那么容易給出來(lái)嗎?你已經(jīng)是個(gè)成熟的程序猿了,需要學(xué)會(huì)自己優(yōu)化代碼了!??!

方法二——對(duì)象

對(duì)象在我眼里一直是倚天屠龍寶刀的存在,了解到其中的奧妙便形同有一武林秘籍傍身。當(dāng)然,沒(méi)用好就相當(dāng)于一堆廢鐵,甚至將導(dǎo)致一些不可預(yù)料的結(jié)果。

function setTreeData(arr) {
    //  刪除所有 children,以防止多次調(diào)用
    arr.forEach(function (item) {
            delete item.children;
    });
    let map = {}; // 構(gòu)建map
    arr.forEach(i => {
        map[i.area_id] = i; // 構(gòu)建以area_id為鍵 當(dāng)前數(shù)據(jù)為值
    });

    let treeData = [];
    arr.forEach(child => {
        const mapItem = map[child.parent_id]; // 判斷當(dāng)前數(shù)據(jù)的parent_id是否存在map中

        if (mapItem) { // 存在則表示當(dāng)前數(shù)據(jù)不是最頂層數(shù)據(jù)
        
            // 注意: 這里的map中的數(shù)據(jù)是引用了arr的它的指向還是arr,當(dāng)mapItem改變時(shí)arr也會(huì)改變,踩坑點(diǎn)
            (mapItem.children || ( mapItem.children = [] )).push(child); // 這里判斷mapItem中是否存在children, 存在則插入當(dāng)前數(shù)據(jù), 不存在則賦值children為[]然后再插入當(dāng)前數(shù)據(jù)
        } else { // 不存在則是組頂層數(shù)據(jù)
            treeData.push(child);
        }
    });

    return treeData;
};

console.log(setTreeData(data)); // 輸出整理后的數(shù)據(jù)

結(jié)果我就不執(zhí)行了,跟遞歸的結(jié)果相似。相比起遞歸,我更喜歡這種方法。不過(guò)這種方法有一種容易犯錯(cuò)的地方,就是它會(huì)改變?cè)瓟?shù)據(jù),我就在這里踩了好久的坑,所以一開(kāi)始采用了刪除children的初始化了一遍。 記住了嗎,沒(méi)記住自行重復(fù)說(shuō)三遍?。。?/p>總結(jié)

以上簡(jiǎn)單介紹了兩種將扁平化數(shù)據(jù)轉(zhuǎn)化為遞歸樹(shù)的方法,學(xué)會(huì)了嗎,沒(méi)學(xué)會(huì)再回去好好擼擼碼!!目前我遇到需要將數(shù)據(jù)整理樹(shù)形結(jié)構(gòu)的主要在菜單欄或分類(lèi)的樹(shù)形結(jié)構(gòu)上,當(dāng)然還有像省市這種有從屬關(guān)系的結(jié)構(gòu)。

關(guān)于JavaScript如何實(shí)現(xiàn)無(wú)限級(jí)遞歸樹(shù)問(wèn)題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒(méi)有解開(kāi),可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站制作公司行業(yè)資訊頻道了解更多相關(guān)知識(shí)。


網(wǎng)站名稱(chēng):JavaScript如何實(shí)現(xiàn)無(wú)限級(jí)遞歸樹(shù)-創(chuàng)新互聯(lián)
網(wǎng)站URL:http://weahome.cn/article/hipoh.html

其他資訊

在線咨詢(xún)

微信咨詢(xún)

電話咨詢(xún)

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部