JavaScript 列表树 js的创建

JavaScript 列表树 js的创建

        let data = {
            "Fish": {
                "trout": {},
                "salmon": {}
            },

            "Tree": {
                "Huge": {
                    "sequoia": {},
                    "oak": {}
                },
                "Flowering": {
                    "apple tree": {},
                    "magnolia": {}
                }
            }
        };

创建该列表,如图
在这里插入图片描述

/*
//第一种
 <li>p
    <ul>

    </ul>
 </li>
 //第二种
    <li>p</li>
    */
        function createTree(container, data){
            for(let p in data){
                //创建当前节点 
                if(data[p]!=null){ //非空就是个队列 <ul>finish<ul>tourish</ul>
                    let li = document.createElement("li");
                    li.prepend(p);   
                    container.append(li); 
                    let ul = document.createElement("ul"); 
                    li.append(ul);
                    createTree(ul, data[p]);
                }
                else{
                    let li = document.createElement("li");
                    li.innerHTML = p;
                    container.append(li);
                }
            }
        }
        createTree(container,data);

在此基础上,再标出子节点的个数 ,如图在这里插入图片描述

        createTree(container, data); //树已创建
        //下来标出后代数量 container
        for (let ele of container.querySelectorAll("li")) {
            ele.firstChild.data += ele.querySelectorAll("li").length;
        }

不可使用innerHTML 否则会将标签也消除掉,每个文本是li中的第一个节点,因此采用ele.firstChild选中该节点,再将data换掉。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值