js递归添加元素怎样防止重复添加?

发布于 2022-09-03 08:58:40 字数 2567 浏览 24 评论 0

我有一串数据

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
                }
            ]
        }
    ]

页面结构如下

<div id="tree">
        <section class="left"></section>
        <section class="right"></section>
</div>

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

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

        for(var i=0; i<data.length; i++) {
            var ul = $('<ul></ul>');

            dom += '<li id="'+data[i].id+'"><a href="###" data-content="'+data[i].content+'">'+data[i].name+'</a></li>';
            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'))

输出结果重复计算了

clipboard.png

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

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

不顾 2022-09-10 08:58:40

好吧,我发现问题了

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是层层递进加一的,看到这我想到可能是这个问题,好吧,看来还是基础差了点。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文