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])

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

总结

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

相关文章

  • 使用useImperativeHandle时父组件第一次没拿到子组件的问题

    使用useImperativeHandle时父组件第一次没拿到子组件的问题

    这篇文章主要介绍了使用useImperativeHandle时父组件第一次没拿到子组件的问题及解决,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • React受控组件与非受控组件详细介绍

    React受控组件与非受控组件详细介绍

    具体来说这是一种react非受控组件,其状态是在input的react内部控制,不受调用者控制。可以使用受控组件来实现。下面就说说这个React中的受控组件与非受控组件的相关知识,感兴趣的朋友一起看看吧
    2022-09-09
  • React中jquery引用的实现方法

    React中jquery引用的实现方法

    这篇文章主要介绍了React中jquery引用的实现方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-09-09
  • React通过conetxt实现多组件传值功能

    React通过conetxt实现多组件传值功能

    Context 提供了一种在组件之间共享此类值的方式,而不必显式地通过组件树的逐层传递 props。本文给大家介绍React通过conetxt实现多组件传值功能,感兴趣的朋友一起看看吧
    2021-10-10
  • React createRef循环动态赋值ref问题

    React createRef循环动态赋值ref问题

    这篇文章主要介绍了React createRef循环动态赋值ref问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-01-01
  • react中使用better-scroll滚动插件的实现示例

    react中使用better-scroll滚动插件的实现示例

    滚动在很多地方都可以使用,本文主要介绍了react中使用better-scroll滚动插件的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-07-07
  • React状态管理的简明指南

    React状态管理的简明指南

    Redux 是React最常用的集中状态管理工具,本文主要介绍了React状态管理的简明指南,具有一定的参考价值,感兴趣的可以了解一下
    2024-01-01
  • ahooks整体架构及React工具库源码解读

    ahooks整体架构及React工具库源码解读

    这篇文章主要为大家介绍了ahooks整体架构及React工具库的源码解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07
  • react项目引入antd框架方式以及遇到的一些坑

    react项目引入antd框架方式以及遇到的一些坑

    这篇文章主要介绍了react项目引入antd框架方式以及遇到的一些坑,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-03-03
  • React Hooks 实现的中文输入组件

    React Hooks 实现的中文输入组件

    这篇文章主要为大家介绍了React Hooks实现的中文输入组件示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-05-05

最新评论