多层级联菜单 toTree
当所有的数据作为一个数组返回,怎么去将数据处理成我们方便渲染的json结构
我使用了递归,但是结果不理想 , 代码结构不清晰,可读性差,想了又想,可以通过以下方式来做到多级菜单的处理
解放方案一
- 多用字典,巧用index, id = index
缩短数据结构
toTree(data) {
// 删除 所有 children,以防止多次调用
data.forEach( (item) => {
item.title = item.categoryName,
item.expand = false,
delete item.children
});
// 将数据存储为 以 id 为 KEY 的 map 索引数据列
let map = {};
data.forEach(function (item) {
map[item.categoryId] = item;
});
let val = [];
data.forEach(function (item) {
// 以当前遍历项,的pid,去map对象中找到索引的id
let parent = map[item.parentId];
//如果找到索引,那么说明此项不在顶级当中,那么需要把此项添加到,他对应的父级中
if (parent) {
(parent.children || ( parent.children = [] )).push(item);
} else {
//如果没有在map中找到对应的索引ID,那么直接把 当前的item添加到 val结果集中,作为顶级
val.push(item);
}
});
return val;
},
解决方案二