js递归方法创建节点

var jsonData =
            [{"subnetId":1,"subnetNode":-1,"subnetRemark":"状态自带","subnetName":"中心网络"},
                {"subnetId":2,"subnetNode":1,"subnetRemark":"好好的","subnetName":"北京"},
                {"subnetId":3,"subnetNode":1,"subnetRemark":"大唐电信","subnetName":"大唐电信"},
                {"subnetId":4,"subnetNode":1,"subnetRemark":"","subnetName":"上海"},
                {"subnetId":5,"subnetNode":4,"subnetRemark":"","subnetName":"中国联通"},
                {"subnetId":6,"subnetNode":3,"subnetRemark":"","subnetName":"移动"},
                {"subnetId":7,"subnetNode":2,"subnetRemark":"","subnetName":"你好"}];

有数组如上,用递归的方式实现一下效果,

subnetId与subnetNode相等时,subnetId作为父节点,subnetNode作为子节点

 function show(data,node){
        var ul = "<ul>";
        for(var i=0;i<data.length;i++){
           if(data[i]!=null){
               if(data[i].subnetNode==node){
                   ul += "<li style='margin-left:10px;'>"+data[i].subnetName;
                   ul += show(data,data[i].subnetId);
                   ul += "</li>";
               }
           }
        }
        ul+="</ul>";
        return ul;
    }
    var a = show(jsonData,-1);
    console.log(a);
    var div = document.createElement(div);
    div.innerHTML = a;
    document.body.appendChild(div);

 

转载于:https://www.cnblogs.com/lmy2016/p/6120647.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值