我是靠谱客的博主 细心牛排,最近开发中收集的这篇文章主要介绍react中usestate改变值不渲染怎么办,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

本教程操作环境:Windows10系统、react17.0.1版、Dell G3电脑。

react中usestate改变值不渲染怎么办

React中默认浅监听,当State值为对象时,栈中存的是对象的引用(地址),setState改变的是堆中的数据

所以此时 setArr(arr) 后,栈中的地址还是原地址,React浅监听到地址没变,故会认为State并未改变,故没有重渲染页面

解决

思路:将栈中原arr所指向的地址改变即可

示例如下:

1)直接setState(要修改的值)

const [arr, setArr] = useState([])
setArr(1)
登录后复制

2)新创建一个数组newArr,将原数组的值赋值给新数组,并setState(newArr)

const [arr, setArr] = useState([])
const newArr = arr.slice(1)
setArr(newArr)
登录后复制

利用ES6的拓展符

const [arr, setArr] = useState([])
setArr([...arr])
登录后复制

推荐学习:《react视频教程》

以上就是react中usestate改变值不渲染怎么办的详细内容,更多请关注靠谱客其它相关文章!

最后

以上就是细心牛排为你收集整理的react中usestate改变值不渲染怎么办的全部内容,希望文章能够帮你解决react中usestate改变值不渲染怎么办所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(76)

评论列表共有 0 条评论

立即
投稿
返回
顶部