React Table dataSource 更新,Table未重新渲染

例子

直接给出未更新例子
可能跟你所写的代码不一样,但是可以参考看看

const [tableData,settableData]=useState(Array)

const columns=[
...
]

let change=(value)=>{
	//*
	let tabledata=tableData
	tabledata.push(value)
	settableData(tabledata)
	...
}

...

return(
	<Table
		 columns={columns}
		 dataSource={tableData}
	/>)

原因

  打了*号的这个写法,虽然把tableDta取出,然后直接push,但其实所指向的都是一个地址,因此这只改变了这个地址指向的内存数据。
  但就是因为指向了一个地址,React认为虚拟DOM并没有改变,因此,不会重新渲染页面。这就会导致Table组件的dataSource改变了,但是Table并没有重新渲染。

解决方法

这里给出我的解决办法,我自己觉得效果还不错,如果有更多解决办法,欢迎评论,可以在后面加上

数据需要处理时


let change=(value)=>{
	let tabledata=[]
	tableData.forEach(element=>{
	   //处理步骤
	   ...
		tabledata.push(element)
	})
	//处理步骤
	 ...
	tabledata.push(value)
	settableData(tabledata)
	...
}

不需要处理时


let change=(value)=>{
	let tabledata=[...tableData]
	//处理步骤
	 ...
	tabledata.push(value)
	settableData(tabledata)
	...
}

解决原理也很简单,新建一个Array指向不同地址,再赋值,这样React就会认为需要重新渲染Table了

如果帮助到你,能点个赞吗?

  • 7
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值