React中的useState如何改变值不重新渲染的问题

 更新时间:2024年03月12日 09:28:15   作者:大盗夕落  
这篇文章主要介绍了React中的useState如何改变值不重新渲染的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

用useState改变值不重新渲染的问题

不渲染

const [lists,setLists] =useState([]);
         .....
    const arr = lists;  
    arr.splice(index,1)  //根据删除index下标的这一项
    setLists([arr]);  //重复设置要改变数组的地址

解决办法

const [lists,setLists] =useState([]);
         .....
    const arr = lists;  
    arr.splice(index,1)  //根据删除index下标的这一项
    setLists([...arr]);  //重复赋值要改变数组的地址

react中数组如果引用地址不变,是不触发重新渲染的,但是值是设置进去了

const [lists,setLists] =useState([]);
         .....
     const arr = [...lists];  //克隆的时候改变地址
     arr.splice(index,1)
      setLists(arr);

这里要根据react的渲染机制源码,因为react 会判断旧状态和新状态是否有变化,如果没有变化就不渲染,所以要改变地址告诉render 是新状态要重新渲染

React踩坑使用useState改变值之后拿不到值问题

最近在项目中发现了一个问题,在使用useState修改值之后,拿不到修改后的值,能肯定的是肯定修改了,不然页面会空白,但是拿不到数据,就很无奈。

最后发现,函数式组件使用useState设置值的方法也是一个异步的方法,而直接输出是同步的,但是还是拿不到值

这个加上await之后保证fectchData函数执行完成之后在输出,应该就会有值,但是输出还是{}

无奈发现,useEffect里面的立即执行函数只会执行一次,因为第二个参数是空数组,导致它没有监听任何数据的值,就相当于类式组件中的componentDidMount钩子,因此只会执行一次

修改代码为:

  useEffect( () => {
      fetchData()
    },[])
 
    useEffect(() => {
      // 监听cityArr的值,第一次肯定为{},等到它有数据之后,在输出
      if(Object.keys(cityArr).length !== 0){
        console.log(cityArr);
        listRef.current.measureAllRows()
      }
    },[cityArr])

如此,就解决了拿不到数据的问题

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • react分页显示数据的方法

    react分页显示数据的方法

    分页在很多地方都可以用到,本文主要实现了react分页显示,主要使用三个组件,父组件listBox、列表组件List、按钮组件PageButton,感兴趣的可以了解一下
    2021-08-08
  • VSCode配置react开发环境的步骤

    VSCode配置react开发环境的步骤

    本篇文章主要介绍了VSCode配置react开发环境的步骤,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-12-12
  • Vite + React从零开始搭建一个开源组件库

    Vite + React从零开始搭建一个开源组件库

    这篇文章主要介绍了Vite + React 如何从0到1搭建一个开源组件库,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-06-06
  • React key值的作用和使用详解

    React key值的作用和使用详解

    这篇文章主要介绍了React key值的作用和使用详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-08-08
  • React路由管理之React Router总结

    React路由管理之React Router总结

    React项目通常都有很多的URL需要管理,最常使用的解决方案就是React Router了,本篇文章主要介绍了React路由管理之React Router总结,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-05-05
  • react使用antd的上传组件实现文件表单一起提交功能(完整代码)

    react使用antd的上传组件实现文件表单一起提交功能(完整代码)

    最近在做一个后台管理项目,涉及到react相关知识,项目需求需要在表单中带附件提交,怎么实现这个功能呢?下面小编给大家带来了react使用antd的上传组件实现文件表单一起提交功能,一起看看吧
    2021-06-06
  • react版模拟亚马逊人机交互菜单的实现

    react版模拟亚马逊人机交互菜单的实现

    本文主要介绍了react版模拟亚马逊人机交互菜单的实现,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-02-02
  • React内部实现cache方法示例详解

    React内部实现cache方法示例详解

    这篇文章主要为大家介绍了React内部实现cache方法示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-11-11
  • 在React框架中实现一些AngularJS中ng指令的例子

    在React框架中实现一些AngularJS中ng指令的例子

    这篇文章主要介绍了在JavaScript的React框架中实现一些AngularJS指令的例子,React使用Virtual DOM因而与普通的js框架有些不同,需要的朋友可以参考下
    2016-03-03
  • 使用react+redux实现计数器功能及遇到问题

    使用react+redux实现计数器功能及遇到问题

    使用redux管理数据,由于Store独立于组件,使得数据管理独立于组件,解决了组件之间传递数据困难的问题,非常好用,今天重点给大家介绍使用react+redux实现计数器功能及遇到问题,感兴趣的朋友参考下吧
    2021-06-06

最新评论