摘要:昨天幫同事解決問題,于是誕生了超優(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
摘要:有這樣一個表,是分類的,是分類名稱,是上級分類的?,F(xiàn)在有個分類,程序要找到它上級的上級的上級分類的,簡單說就是找出頂級分類的。比如新鮮水果的是,對應(yīng)父類是,而的父是,沒有父類,也就是頂級分類了。 有這樣一個表,id是分類的ID,name是分類名稱,pid是上級分類的ID。showImg(https://segmentfault.com/img/bVtnrg); 現(xiàn)在有個分類ID,程序要...
摘要:第三條同樣需要遞歸,因?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)容展...
無限級分類 是一種很常見,很必須的功能,幾乎每個項(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...
閱讀 2735·2021-11-11 17:21
閱讀 627·2021-09-23 11:22
閱讀 3591·2019-08-30 15:55
閱讀 1651·2019-08-29 17:15
閱讀 583·2019-08-29 16:38
閱讀 921·2019-08-26 11:54
閱讀 2517·2019-08-26 11:53
閱讀 2764·2019-08-26 10:31