首页 > web前端 > 前端问答 > react中usestate改变值不渲染怎么办

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

WBOY
发布: 2022-04-29 17:48:59
原创
2853 人浏览过

方法:1、利用“const [arr, setArr]=useState([改变值])”修改State值;2、创建一个新的数组,并将原数组的值赋值给新数组,并用“setState(新数组)”修改State,将栈中原数组所指向的地址改变即可。

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改变值不渲染怎么办的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板