React组件中监听函数获取不到最新的state问题

 更新时间:2024年01月25日 09:09:28   作者:你是KKKK呀  
这篇文章主要介绍了React组件中监听函数获取不到最新的state问题问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

场景

在useEffect事件中,更新setState或者redux后获取到的state值为第一次的值,不是最新的

例如:

export default function Travel(props) {
    const divRef = useRef(null)
    const [count, setCount] = useState(0)
    const handleClick = () => {
        console.log('click',count);
    }
 
    useEffect(() => {
        window.addEventListener('click', handleClick)
        return () => {
            window.removeEventListener('click', handleClick)
        }
    },[])
    console.log('out',count);
 
 
    return (
        <div ref={divRef} >
            <button onClick={() => {
        setCount(count => count + 1)
 
            }}>点击</button>
        </div>
    )
}

又或者

const [flag,setFlag] = useState(false);
  
  const onClick = ()=>{
    setFlag(!flag)
    console.log(flag)
  }
  
  useEffect(() => {
    document.addEventListener('click',onClick)
  }, []);

原因

找了一些资料了解到

因为监听器绑定的是第一次render时生成的函数,这个函数的上下文中的state也是第一次的值,所以即便后面render了多次,因为绑定的是第一次render的函数,所以state值也是旧的。

解决方案1

useEffect(() => {
    window.addEventListener('click', handleClick)
    return () => {
        window.removeEventListener('click', handleClick)
    }
},[count])

监听值的变化,绑定并解绑事件

解决方案2

const stateRef = useRef(0)
const [state,setState] = useState(stateRef.current);
 
const Function = ()=>{
    let data = JSON.parse(JSON.stringify(stateRef));
    /*功能*/
    stateRef.current = newData;
    setState(stateRef.current)
}  

通过useRef创建变量来改变state的值

其他情况

const stateRef = useRef(null);
 
useEffect(() => {
    if (
      !stateRef.current ||
      (reduxState &&
        JSON.stringify(reduxState) !== JSON.stringify(stateRef.current) &&
        JSON.stringify(reduxState.id) !== JSON.stringify(stateRef.current?.id))
    ) {
      sstateRef.current = JSON.parse(JSON.stringify(reduxState));
    }
  }, [reduxState]);

比方说redux缓存了一串数据,这个数据用于控制物体移动,就可以监听redux state,将值赋值给stateRef。

需要注意防止重复赋值,不然会造成抖动。

判断是否数据无变化,判断是否切换了redux的数据。

总结

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

相关文章

  • React中useState的使用方法及注意事项

    React中useState的使用方法及注意事项

    useState通过在函数组件里调用它来给组件添加一些内部state,下面这篇文章主要给大家介绍了关于React中useState的使用方法及注意事项的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-08-08
  • React常见跨窗口通信方式实例详解

    React常见跨窗口通信方式实例详解

    这篇文章主要为大家介绍了React常见跨窗口通信方式实例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • 基于React的状态管理实现一个简单的颜色转换器

    基于React的状态管理实现一个简单的颜色转换器

    这篇文章主要介绍了用React的状态管理,简简单单实现一个颜色转换器,文中有详细的代码示例供大家参考,具有一定的参考价值,需要的朋友可以参考下
    2023-08-08
  • React commit源码分析详解

    React commit源码分析详解

    前两章讲到了,react 在 render 阶段的 completeUnitWork 执行完毕后,就执行 commitRoot 进入到了 commit 阶段,本章将讲解 commit 阶段执行过程源码
    2022-11-11
  • react-native动态切换tab组件的方法

    react-native动态切换tab组件的方法

    在APP中免不了要使用tab组件,有的是tab切换,也有的是tab分类切换.这篇文章主要介绍了react-native动态切换tab组件的方法,非常具有实用价值,需要的朋友可以参考下
    2018-07-07
  • react中路由跳转及传参的实现

    react中路由跳转及传参的实现

    本文主要介绍了react中路由跳转及传参的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-05-05
  • 详解如何在React中执行条件渲染

    详解如何在React中执行条件渲染

    在现代Web开发中,React作为一种流行的JavaScript库,为开发者提供了一种高效构建用户界面的方式,条件渲染是React中的一个关键概念,本文将深入探讨如何在React中实现条件渲染,并通过示例代码演示常见的用法,需要的朋友可以参考下
    2025-01-01
  • React Native 混合开发多入口加载方式详解

    React Native 混合开发多入口加载方式详解

    这篇文章主要介绍了React Native 混合开发多入口加载方式详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-09-09
  • React Fiber 树思想解决业务实际场景详解

    React Fiber 树思想解决业务实际场景详解

    这篇文章主要为大家介绍了React Fiber 树思想解决业务实际场景详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12
  • React 高德地图进京证路线规划问题记录(汇总)

    React 高德地图进京证路线规划问题记录(汇总)

    这篇文章主要介绍了React高德地图进京证路线规划问题小记,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧
    2024-08-08

最新评论