加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

数据处理为树形结构以及多级菜单的逻辑分析

发布时间:2020-12-14 04:19:18 所属栏目:大数据 来源:网络整理
导读:菜单数据源处理: //数据源组装成树形结构(一级与后面的级逻辑相同) 逻辑:遍历所有数据,上级与下次的联动关系相等则数据存放,如果不为最后一级,递归 function getTree(source,data,pid) { var length = source.length; for (var i = 0; i length; i++)

菜单数据源处理:

//数据源组装成树形结构(一级与后面的级逻辑相同)
逻辑:遍历所有数据,上级与下次的联动关系相等则数据存放,如果不为最后一级,递归
function getTree(source,data,pid) {
var length = source.length;
for (var i = 0; i < length; i++) {
var item = source[i];
if (item.pid == pid) {
var obj = {};
obj.title = item.menuName;
obj.value = item.id;
obj.data = [];
data.push(obj);
if (item.menuType != "2") {
arguments.callee(source,obj.data,item.id)
}
}
}
}

//数据源组装成树形结构(一级与后面的级逻辑不同)逻辑:开始遍历所有数据,根据一级关系找出一级,调用二级方法;将2级方法抽离出来,在2级方法中遍历所有数据,并根据一级与2级的关系找出2级function first(data,arr,0){ for(var i =0;i<data.length;i++){ if(data[i].pid == 0){ arr.push(data[i]); two(data,data[i].id); } }}function two (data,pid){ var arr = []; for(var i = 0;i<data[i].length;i++){ if(data[i].pid == pid){ arr.push(data[i]) } } return arr;}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读