欢迎光临
我们一直在努力

react数组变化不更新如何解决

本文小编为大家详细介绍“react数组变化不更新如何解决”,内容详细,步骤清晰,细节处理妥当,希望这篇“react数组变化不更新如何解决”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

react数组变化不更新是因为在js中数组的赋值是引用传递的,其解决办法:1、打开相应的react文件;2、使用扩展运算符,创建一个新数组,更改内存引用;3、使用“panes.push({key: panes.length,tab: `${panes.length + 1}`})”方式重新赋值即可。

react中 一个state数组某元素属性发生变化时,setState页面不更新

写代码过程中,你会发现,如果直接使用push等方法改变state,按理来说,push会改变原数组,数组应该更新,但渲染出来的state并不会更改。

今天遇到的问题是:组件内对数组元素进行修改后数据有变化但是页面没重新渲染

话说这是因为组件没能够识别数组的变化,所以页面没有重新渲染

所以只要让组件感知到你发生了改变,就可以达到刷新的效果

原因:

这是由于js中,数组的赋值是引用传递的,array.push相当于直接更改了数组对应的内存块,但react内部用于对比的array的内存并没有更改,是指向同一个内存的,setState只做shallow compare,因此没有触发re-render。

可以使用扩展运算符,创建一个新数组,更改内存引用

需求:

解决办法:解构后重新赋值

const onClick = (key) => {// tab点击函数
    if (key === 'addTab') {
      panes.push({
        key: panes.length,
        tab: `筛选记录${panes.length + 1}`
      })
      setPanes([...panes])
    }
  }

读到这里,这篇“react数组变化不更新如何解决”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注云搜网行业资讯频道。

赞(0)
【声明】:本博客不参与任何交易,也非中介,仅记录个人感兴趣的主机测评结果和优惠活动,内容均不作直接、间接、法定、约定的保证。访问本博客请务必遵守有关互联网的相关法律、规定与规则。一旦您访问本博客,即表示您已经知晓并接受了此声明通告。