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视频教程》

标签:

商匡云商
Logo
注册新帐户
对比商品
  • 合计 (0)
对比
0
购物车