javascript - js递归添加元素怎样防止重复添加?
黄舟
黄舟 2017-04-11 11:49:54
[JavaScript讨论组]

我有一串数据

data = [
        {
            id: "01",
            name: "上海",
            content: "上海是个是个好地方",
            isleaf: false,
            children: [
                {
                    parent: "01",
                    id: "01-1",
                    name: "黄浦",
                    content: "黄浦是个是个好地方",
                    isleaf: true
                },
                {
                    parent: "01",
                    id: "01-2",
                    name: "静安",
                    content: "静安是个是个好地方",
                    isleaf: true
                },
                {
                    parent: "01",
                    id: "01-3",
                    name: "普陀",
                    content: "普陀是个是个好地方",
                    isleaf: true
                }
            ]
        },
        {
            id: "02",
            name: "北京",
            content: "北京是个是个好地方",
            isleaf: false,
            children: [
                {
                    parent: "02",
                    id: "02-1",
                    name: "朝阳",
                    content: "朝阳是个是个好地方",
                    isleaf: true
                },
                {
                    parent: "02",
                    id: "02-2",
                    name: "东城",
                    content: "东城是个是个好地方",
                    isleaf: true
                }
            ]
        }
    ]

页面结构如下

我想通过一个函数生成一段二级导航,但是这个函数有问题,函数如下:

function buildTree (data, parent) {
        var dom = '';

        for(var i=0; i');

            dom += '
  • '+data[i].name+'
  • '; ul.append(dom); //parent.find('ul:first').remove(); parent.append(ul); if(!data[i].isleaf) { buildTree (data[i].children, $('#'+data[i].id)); } else { } } console.log(dom); } buildTree(data, $('.left'))

    输出结果重复计算了

    我知道问题出在parent.append(ul)这里,但是我不知道怎样修改它,请问这个问题要怎么解决?谢谢了。

    黄舟
    黄舟

    人生最曼妙的风景,竟是内心的淡定与从容!

    全部回复(1)
    PHP中文网

    好吧,我发现问题了

    function buildTree (data, parent) {
            for(var i=0; i<data.length; i++) {
                var ul = $('<ul></ul>');
                var dom = '';
    
                dom += '<li id="'+data[i].id+'"><a href="###" data-content="'+data[i].content+'">'+data[i].name+'</a></li>';
                ul.html(dom);
                parent.append(ul);
    
                if(!data[i].isleaf) {
                    buildTree (data[i].children, $('#'+data[i].id));
                } else {
    
                }
    
            }
    
            console.log(dom);
    
    }

    只要把dom也放到for循环里就行了,我居然看了半天。
    我后来打开f12,发现上海的下面实际上是三个ul,然后每个ul里面的li是层层递进加一的,看到这我想到可能是这个问题,好吧,看来还是基础差了点。

    热门教程
    更多>
    最新下载
    更多>
    网站特效
    网站源码
    网站素材
    前端模板
    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送
    PHP中文网APP
    随时随地碎片化学习

    Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号