可能比较绕,具体是这样的,从接口收到了一个数据,结构大概是这样:
[
{
id: '1',
name: '',
child: [
{id: '5',
name: 'aaa',
child: [
{
id: '1',
name: 'aaa',
child: [
{
id: '1',
name: 'aaa',
child: [
]
}
]
}
]
}
]
},
{
id: '2',
name: '',
child: [
]
}
]
每一层的每一条数据都有独立id,然后有child字段对应第二层数据,第二层数据也有child字段对应第三层数据等等……
请问有没有高效一点的方法,通过一个指定id,从这个树状数据中取得相对应的name?求个封装函数
根据你要求和提供的数据样本,写了个demo,不知道符不符合你的要求。通过一个指定id,返回当前对象
运行结果
注:
demo( data, id )
中的id
必须是唯一的正道: 递归;
歪道: 对象 JSON.Stringify 以后,用正则匹配 "id":"xx" 后,获取第一个 "name:" 和 ","之间的字符串