成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

超優(yōu)雅!node.js 無限級分類,無遞歸獲取所有下級分類ID。

calx / 739人閱讀

摘要:昨天幫同事解決問題,于是誕生了超優(yōu)雅兩行代碼搞定無限級分類獲取頂級分類這篇文章。這次要解決的問題是根據(jù)分類,獲取所有下級分類的,這里說的所有下級分類,是包含下級下下級下下下級另外剛好在學(xué)習(xí),于是用上了對象。

昨天幫同事解決問題,于是誕生了“超優(yōu)雅!兩行代碼搞定 php 無限級分類 獲取頂級分類ID”這篇文章。

晚上回家做自己的node.js項(xiàng)目的時候,又遇到關(guān)于無限級分類的問題了。
其實(shí)也不是“遇到”,而是強(qiáng)迫癥發(fā)作 不睡覺 干脆起床,把之前用遞歸現(xiàn)實(shí)的版本,改成用循環(huán)實(shí)現(xiàn)了。

這次要解決的問題是:根據(jù)分類ID,獲取所有下級分類的ID,
這里說的“所有下級分類”,是包含下級、下下級、下下下級……

另外剛好在學(xué)習(xí)ES6,于是用上了Set對象。
首先還是要將數(shù)據(jù)處理成{ id:pid, ... }這種格式,以下是我的數(shù)據(jù)。

var idPidArr = {
  "1": 2,
  "2": 0,
  "3": 2,
  "4": 43,
  "5": 2,
  "6": 2,
  "7": 0,
  "8": 0,
  "9": 1,
  "10": 1,
  "11": 1,
  "12": 1,
  "13": 1,
  "14": 1,
  "15": 0,
  "16": 1,
  "17": 102,
  "18": 43,
  "19": 43,
  "20": 3,
  "21": 3,
  "22": 43,
  "23": 43,
  "24": 5,
  "25": 43,
  "26": 43,
  "27": 43,
  "28": 4,
  "29": 4,
  "30": 4,
  "31": 43,
  "32": 111,
  "33": 5,
  "34": 43,
  "35": 5,
  "36": 88,
  "37": 43,
  "38": 43,
  "39": 43,
  "40": 6,
  "41": 70,
  "42": 6,
  "43": 0,
  "44": 43,
  "45": 43,
  "46": 8,
  "47": 8,
  "48": 43,
  "49": 8,
  "50": 43,
  "51": 67,
  "52": 125,
  "53": 43,
  "54": 43,
  "55": 124,
  "56": 0,
  "57": 6,
  "58": 6,
  "59": 111,
  "60": 43,
  "61": 43,
  "62": 56,
  "63": 43,
  "64": 4,
  "65": 43,
  "66": 43,
  "67": 102,
  "68": 43,
  "69": 4,
  "70": 102,
  "71": 56,
  "72": 124,
  "73": 43,
  "74": 43,
  "75": 8,
  "76": 17,
  "77": 43,
  "78": 0,
  "79": 43,
  "80": 43,
  "81": 103,
  "82": 15,
  "83": 17,
  "84": 3,
  "85": 15,
  "86": 3,
  "87": 43,
  "88": 43,
  "89": 111,
  "90": 43,
  "91": 15,
  "92": 6,
  "93": 6,
  "94": 43,
  "95": 53,
  "96": 103,
  "97": 111,
  "98": 6,
  "99": 70,
  "100": 15,
  "101": 6,
  "102": 0,
  "103": 43,
  "104": 103,
  "105": 103,
  "106": 103,
  "107": 7,
  "108": 7,
  "109": 7,
  "110": 7,
  "111": 102,
  "112": 8,
  "113": 1,
  "114": 103,
  "115": 103,
  "116": 43,
  "117": 43,
  "118": 43,
  "119": 125,
  "120": 111,
  "121": 70,
  "122": 111,
  "123": 70,
  "124": 8,
  "125": 8,
  "126": 124,
  "127": 125,
  "128": 88,
  "129": 43,
  "130": 3,
  "131": 43,
  "132": 43,
  "133": 86,
  "134": 21,
  "135": 21,
  "136": 86,
  "137": 20,
  "138": 20 };

然后 假設(shè)要獲取分類 ID: 8 的所有下級分類的 ID。

var bmid = 8;

var pids = new Set([bmid]);
do {
    var len = pids.size;

    for(var id in idPidArr) {
        if (pids.has(idPidArr[id])) {
            pids.add(Number(id));
            delete idPidArr[id]; // 感謝 @zhoutk 提醒
        }
    }
} while (pids.size>len);

console.log(Array.from(pids));

輸出所有下級分類 ID 數(shù)組是 [ 8, 46, 47, 49, 75, 112, 124, 125, 126, 127, 52, 55, 72, 119 ]

然后……沒有了,
為什么有一種虎頭蛇尾的感覺呢?
代碼已經(jīng)夠簡潔了,應(yīng)該不必逐行解釋了吧……

哎~ 為什么我可以寫出如此精妙的代碼,
卻永遠(yuǎn)猜不透“石化油服”的走勢?。?!
來一首五月天的《超人》體會一下我此刻的心情。

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/78862.html

相關(guān)文章

  • 優(yōu)雅!兩行代碼搞定 php 分類 獲取分類ID

    摘要:有這樣一個表,是分類的,是分類名稱,是上級分類的?,F(xiàn)在有個分類,程序要找到它上級的上級的上級分類的,簡單說就是找出頂級分類的。比如新鮮水果的是,對應(yīng)父類是,而的父是,沒有父類,也就是頂級分類了。 有這樣一個表,id是分類的ID,name是分類名稱,pid是上級分類的ID。showImg(https://segmentfault.com/img/bVtnrg); 現(xiàn)在有個分類ID,程序要...

    hedzr 評論0 收藏0
  • 在數(shù)據(jù)庫中存儲一棵樹,實(shí)現(xiàn)分類

    摘要:第三條同樣需要遞歸,因?yàn)橥ㄟ^一個分類,數(shù)據(jù)庫中只存儲了其直屬父類,需要通過遞歸到頂級分類才能獲取到它們之間的所有分類信息。 原文發(fā)表于我的博客: https://blog.kaciras.net/article/36 在一些系統(tǒng)中,對內(nèi)容進(jìn)行分類是必需的功能。比如電商就需要對商品做分類處理,以便于客戶搜索;論壇也會分為很多板塊;門戶網(wǎng)站、也得對網(wǎng)站的內(nèi)容做各種分類。 分類對于一個內(nèi)容展...

    Airy 評論0 收藏0
  • PHP 分類最佳實(shí)踐

    無限級分類 是一種很常見,很必須的功能,幾乎每個項(xiàng)目都有。 應(yīng)用場景:下拉列表,樹型列表等 無限級分類的類型 前端實(shí)現(xiàn)(前端框架一般已經(jīng)實(shí)現(xiàn)好了,只要后端按照指定格式傳數(shù)據(jù)給前端就可以生成了) 后端實(shí)現(xiàn)(下面主要講這種實(shí)現(xiàn)) 無限級多種實(shí)現(xiàn) 第一種(推薦) function infiniteSort($data, $showFName, $titleFName, $pidFName = p...

    yzzz 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<