我現(xiàn)在有一個(gè)數(shù)組對(duì)象,數(shù)組中的每個(gè)對(duì)象下可能存在子集,也可能不存在,目前我用循環(huán)遞歸的方法把數(shù)據(jù)解析出來了,但是我現(xiàn)在不知道該怎么在數(shù)組的每一層添加它們自己的標(biāo)識(shí),意思就是說,如果數(shù)組中的某一項(xiàng)沒有子集,則該數(shù)組的層次是1;如果數(shù)組中的某一項(xiàng)有子集,且這個(gè)子集自己也有子集,那這一項(xiàng)的層次該如何標(biāo)識(shí)出來,具體的代碼和截圖可以看下面的描述
`
let arr = [
{
title: '我是標(biāo)題1,我沒有子集',
href: 'xxxxx',
children: []
},
{
title: '我是標(biāo)題2,我沒有子集',
href: 'xxxxx',
children: [
{
title: '我是標(biāo)題2的子集,我沒有子集',
href: 'xxxxx',
children: []
},
{
title: '我是標(biāo)題2的子集,我沒有子集',
href: 'xxxxx',
children: []
},
{
title: '我是標(biāo)題2的子集,我有子集',
href: 'xxxxx',
children: [
{
title: '我是標(biāo)題2的子集的子集,我沒有子集',
href: 'xxxxx',
children: []
},
{
title: '我是標(biāo)題2的子集的子集,我沒有子集',
href: 'xxxxx',
children: []
},
{
title: '我是標(biāo)題2的子集的子集,我沒有子集',
href: 'xxxxx',
children: []
}
]
}
]
},
{
title: '我是標(biāo)題3,我有子集',
href: 'xxxxx',
children: []
}
]
arr.forEach(item => {
test(item)
})
function test(item) {
if (item.children.length) {
item.children.forEach(ele => {
ele.div = '<div>'+ele.title+'</div>'
test(ele)
})
} else {
item.div = '<div>'+item.title+'</div>'
}
}
console.log(arr)
`
如上描述,有人能給出一個(gè)解決方法或者提示信息嗎?多謝各位
看你的需求,用遞歸來做會(huì)好一些,但是這個(gè)尾遞歸很難進(jìn)行優(yōu)化
因?yàn)檫@個(gè)類似的需求肯定是要先獲取到最深層的節(jié)點(diǎn),為了避免一些重復(fù)計(jì)算,就很難做成尾遞歸的形式,因?yàn)樯洗握{(diào)用棧的信息需要存儲(chǔ),在內(nèi)部函數(shù)執(zhí)行完畢后拿到結(jié)果再進(jìn)行賦值:
func(data)
console.log(data)
function func(data) {
data.forEach(item => {
item.depth = getDepth(item)
})
}
function getDepth(data) {
return data.children.length ? Math.max(...data.children.map(child => {
child.depth = getDepth(child)
return (child.depth || 0) + 1
})) : 1
}
P.S. 這兩個(gè)函數(shù)可以合并為一個(gè),就留給你自己練手咯
北大青鳥APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國(guó)IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國(guó)家
北大青鳥中博軟件學(xué)院創(chuàng)立于2003年,作為華東區(qū)著名互聯(lián)網(wǎng)學(xué)院和江蘇省首批服務(wù)外包人才培訓(xùn)基地,中博成功培育了近30000名軟件工程師走向高薪崗位,合作企業(yè)超4
中公教育集團(tuán)創(chuàng)建于1999年,經(jīng)過二十年潛心發(fā)展,已由一家北大畢業(yè)生自主創(chuàng)業(yè)的信息技術(shù)與教育服務(wù)機(jī)構(gòu),發(fā)展為教育服務(wù)業(yè)的綜合性企業(yè)集團(tuán),成為集合面授教學(xué)培訓(xùn)、網(wǎng)
達(dá)內(nèi)教育集團(tuán)成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機(jī)構(gòu),是中國(guó)一站式人才培養(yǎng)平臺(tái)、一站式人才輸送平臺(tái)。2014年4月3日在美國(guó)成功上市,融資1
曾工作于聯(lián)想擔(dān)任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項(xiàng)目經(jīng)理從事移動(dòng)互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍(lán)懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負(fù)責(zé)iOS教學(xué)及管理工作。
浪潮集團(tuán)項(xiàng)目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺(tái)面向?qū)ο箝_發(fā)經(jīng)驗(yàn),技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點(diǎn)難點(diǎn)突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫(kù),具有快速界面開發(fā)的能力,對(duì)瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁(yè)制作和網(wǎng)頁(yè)游戲開發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開發(fā)經(jīng)驗(yàn)。曾經(jīng)歷任德國(guó)Software AG 技術(shù)顧問,美國(guó)Dachieve 系統(tǒng)架構(gòu)師,美國(guó)AngelEngineers Inc. 系統(tǒng)架構(gòu)師。