如何理解这段代码的运行?

作者站长头像
站长
· 阅读数 4
  function createTree(deep) {
            let children = {};
            let tree = { id: 0 ,children};
            for (let i = 1; i <= deep; i++) {
                children.id = i;
                children.children = {}
                children = children.children; //不太理解这里
            }
            return tree;
        }
        let tree = createTree(6);

看他每次循环都只生成了一个节点,怎么把他遍历到tree中的呢?

回复
1个回答
avatar
test
2024-07-06

answer image

为防止混淆改一下, children 改为了 obj

  function createTree (deep) {
    let obj = {};
    let tree = { id: 0, obj };
    for (let i = 1; i <= deep; i++) {
      obj.id = i;
      // 给obj新建一个名字为children的键, 值为空对象
      obj.children = {}
    // 使用倒叙创建了 children 给obj, 
      // 然后将变量obj的值改为上面上面的新建的children, 其实就是改变了其指向
      obj = obj.children;
    }
    return tree;
  }
  let tree = createTree(6);
  console.log(tree);

answer image

回复
likes
适合作为回答的
  • 经过验证的有效解决办法
  • 自己的经验指引,对解决问题有帮助
  • 遵循 Markdown 语法排版,代码语义正确
不该作为回答的
  • 询问内容细节或回复楼层
  • 与题目无关的内容
  • “赞”“顶”“同问”“看手册”“解决了没”等毫无意义的内容