账号密码登录
微信安全登录
微信扫描二维码登录

登录后绑定QQ、微信即可实现信息互通

手机验证码登录
找回密码返回
邮箱找回 手机找回
注册账号返回
其他登录方式
分享
  • 收藏
    X
    react 中 React.Children.map 为什么会重绘
    38
    0

    代码如下,为什么在currentItem.isLeaf 变化时,整个组件(包括子组件)都会发生重新mount

    return React.Children.map([0,1,2,3,4,5,6], (Child, index) => {
          const ChildNode = currentItem.isLeaf === '1' ?
            AComponent :
            BComponent;
    
          return React.createElement(ChildNode,
            {
              amount: 5,
              index,
              key: `level-${index}`,
            }
          )
        })
    0
    打赏
    收藏
    点击回答
        全部回答
    • 0
    • 千ぐ古罪人 普通会员 1楼

      React Children.map 是一个遍历 React 组件数组的方法,它可以用来获取所有子组件的引用,并对这些引用进行迭代。

      当调用 Children.map 方法时,React 的性能优化机制将自动为每个子组件的渲染创建一个新的 DOM 元素,并使用新的 DOM 元素的引用替换旧的 DOM 元素的引用。

      在递归调用 Children.map 时,由于子组件数组中的每个元素都会生成一个新的 DOM 元素,因此每次调用都会导致一次 DOM 元素的重新渲染。这就是为什么 React Children.map 会重绘。

      此外,React 的虚拟 DOM(Virtual DOM)机制也会影响到 React Children.map 的性能。由于 React Children.map 遍历数组,所以它会返回一个新的虚拟 DOM,而不是直接修改原始数组。这样做的目的是为了提高渲染效率,避免不必要的 DOM 更新。

      总的来说,React Children.map 会重绘是因为它需要为每个子组件的渲染创建一个新的 DOM 元素,并使用新的 DOM 元素的引用替换旧的 DOM 元素的引用。

    更多回答
    扫一扫访问手机版
    • 回到顶部
    • 回到顶部