父級找子集直接點就行了,子集找父級呢?怎么操作
let arrn=[
{
"MENU_URL": "dashboard",
"MENU_ID": "104a580029c54e139210b7e87dca6d89",
"MENU_NAME": "監(jiān)控面板"
},
{
"MENU_URL": "systemManage",
"MENU_ID": "769130d1918d47219e6f0c463a1c9c67",
"MENU_NAME": "系統(tǒng)管理"
},
{
"MENU_URL": "serviceManage",
"MENU_ID": "8619ca0b6fbc42649a27475e339d5d4a",
"MENU_INFO": [
{
"MENU_URL": "userInfo",
"MENU_ID": "104a580029c54e139210b7e87dca6d89",
"MENU_NAME": "三戶信息"
}
],
"MENU_NAME": "業(yè)務管理"
},
{
"MENU_URL": "serviceManage/recordQuery",
"MENU_ID": "d379e3f38cb3472ab18287034f32ef46",
"MENU_INFO": [
{
"MENU_URL": "dashboard",
"MENU_ID": "104a580029c54e139210b7e87dca6d80",
"MENU_INFO": [
{
"MENU_URL": "dashboard",
"MENU_ID": "454a580029c54e139210b7e87dca6d82",
"MENU_NAME": "監(jiān)控面板222"
}
],
"MENU_NAME": "監(jiān)控面板111"
},
{
"MENU_URL": "dashboard",
"MENU_ID": "104a580029c54e139210b7e87dca6d89",
"MENU_NAME": "監(jiān)控面板333"
}
],
"MENU_NAME": "訂購信息查詢"
}
]
知道監(jiān)控面板222的MENU_ID,要找到最外層的MENU_ID
現(xiàn)在寫了一個能從第二級找到第一級
```
function getParentId(childId) {
tmparr.forEach(function (item, index) {
if (item.MENU_INFO) {
item.MENU_INFO.forEach(function (list, idx) {
if (list.MENU_ID === childId) {
console.log('d', item)
}
})
}
})
}
getParentId('104a580029c54e139210b7e87dca6d80')
```
有沒有高手可以改造一下,用遞歸什么的,查不定級數(shù)的
有個很巧的辦法:把Menu對應的數(shù)組對象arrn轉成字符串,然后使用正則查找,異常輕松,可以適配無限深的層級。
function findTopParent(menuJson, childId) {
let menuStr = JSON.stringify(menuJson);
let reg = new RegExp('MENU_ID":"([^"]+)"[^\\}\\]]+MENU_ID":"' + childId);
return reg.test(menuStr) ? menuStr.match(reg)[1]: undefined;
}
findTopParent(arrn, '104a580029c54e139210b7e87dca6d89'); //返回8619ca0b6fbc42649a27475e339d5d4a
findTopParent(arrn, '454a580029c54e139210b7e87dca6d82'); //返回d379e3f38cb3472ab18287034f32ef46
遞歸遍歷
function findParentById(arr,id){
var parentId = '沒有父元素',
hasParentId = function loop(arr){
return arr.some((item)=>{
if(item.MENU_ID === id){
return true
}else if(Array.isArray(item.MENU_INFO)){
parentId = item.MENU_ID
return loop(item.MENU_INFO)
}else{
return false
}
})
}(arr)
return hasParentId ? parentId : '未找到對應父元素'
}
function findParentsById(arr,id){
var parentIds = [],
index = 0,
hasParentId = function loop(arr, index){
return arr.some((item)=>{
if(item.MENU_ID === id){
parentIds = parentIds.slice(0, index)
return true
}else if(Array.isArray(item.MENU_INFO)){
parentIds[index] = item.MENU_ID
return loop(item.MENU_INFO, index+1)
}else{
return false
}
})
}(arr, index)
return hasParentId ? parentIds : []
}
findParentById(arrn, '454a580029c54e139210b7e87dca6d82');//"104a580029c54e139210b7e87dca6d80"
findParentsById(arrn, '454a580029c54e139210b7e87dca6d82');
//["d379e3f38cb3472ab18287034f32ef46", "104a580029c54e139210b7e87dca6d80"]
這里用104a580029c54e139210b7e87dca6d89
測試,發(fā)現(xiàn)一直找不到,最后看到你id很對重復的,比如第一條數(shù)據(jù)的id也是這個,那么這只是你的測試數(shù)據(jù)還是數(shù)據(jù)就是這樣的可以重復?如果可以重復那上面的代碼就需要改下,不過都是遞歸
北大青鳥APTECH成立于1999年。依托北京大學優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
北大青鳥中博軟件學院創(chuàng)立于2003年,作為華東區(qū)著名互聯(lián)網(wǎng)學院和江蘇省首批服務外包人才培訓基地,中博成功培育了近30000名軟件工程師走向高薪崗位,合作企業(yè)超4
中公教育集團創(chuàng)建于1999年,經(jīng)過二十年潛心發(fā)展,已由一家北大畢業(yè)生自主創(chuàng)業(yè)的信息技術與教育服務機構,發(fā)展為教育服務業(yè)的綜合性企業(yè)集團,成為集合面授教學培訓、網(wǎng)
達內(nèi)教育集團成立于2002年,是一家由留學海歸創(chuàng)辦的高端職業(yè)教育培訓機構,是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
曾工作于聯(lián)想擔任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔任項目經(jīng)理從事移動互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍懿科技有限責任公司從事總經(jīng)理職務負責iOS教學及管理工作。
浪潮集團項目經(jīng)理。精通Java與.NET 技術, 熟練的跨平臺面向對象開發(fā)經(jīng)驗,技術功底深厚。 授課風格 授課風格清新自然、條理清晰、主次分明、重點難點突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應用開發(fā)經(jīng)驗。曾經(jīng)歷任德國Software AG 技術顧問,美國Dachieve 系統(tǒng)架構師,美國AngelEngineers Inc. 系統(tǒng)架構師。