• 技术文章 >web前端 >前端问答

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

    长期闲置长期闲置2022-04-29 17:48:59原创376

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

    本教程操作环境: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中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:React
    上一篇:react生命周期分为几个阶段 下一篇:cordova和react有什么区别
    千万级数据并发解决方案

    相关文章推荐

    • angular、react和vue有什么区别• react的虚拟dom有什么用• react能实现依赖注入吗• react中redux有中间件吗• react调用setstate后发生了什么
    1/1

    PHP中文网