React中异步数据更新不及时问题及解决

 更新时间:2024年03月22日 15:04:48   作者:裤头青蛙  
这篇文章主要介绍了React中异步数据更新不及时问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

react异步数据更新不及时问题

最近在学习react的过程中,遇到了个问题,当我使用useState这个hook的时候,发现我们这个方法更新数据他是异步更新的,数据不会及时同步上我们的页面,在仔细的研究下,找到了以下

解决方法

const [value,setValue] = useState([]);
const changeValue = ()=>{
    setValue(data)
    console.log(value) //在此处输出会出现不及时更新问题,不会同步到页面上
}
 
//利用useEffect这个hook来监听数据的变化再去输出或者是调用
useEffect(()=>{
    console.log(value)//这样就可以解决更新不及时的问题啦
},[value])

react异步更新、寻找DOM

1.react异步更新

react异步更新指的是this.setState()是异步更新的,异步更新之后怎么获取更新之后值

有两种方法:

1.1 componentDidUpdate生命周期函数获取更新之后的值

componentDidUpdate:已经更新生命周期函数中打印state中的数据是更新后的值

  componentDidUpdate(prevProps, prevState) {
        console.log(2, prevState.name, this.state.name)  // 张三, 李四
  }

1.2 在this.setState()的回调函数中获取更新后的值

this.setState的第二个参数是可选的回调,是异步更新完成时的回调,在该回调函数中获取更新后的值

this.setState({
                 name: "李四"
                }, ()=>{
// this.setState的第二个参数是可选的回调, 是异步更新完成时的回调 (与小程序setData相同)
                 console.log(3, this.state.name)  // 李四
                // 注意: this.setState数据更新属于异步更新, 此处打印是更新前的值 
                console.log(1, this.state.name)  // 张三

2.react查找DOM

在react组件中获取DOM元素的三种方式:

2.1 给标签设置ref属性

给标签设置ref属性,通过this.refs调用(老版本语法,将要废除)

<h1 ref="myH1"></h1>
this.refs.myH1

2.2 在构造器中创建ref全局变量

在构造器中创建ref全局变量,在标签中ref属性动态绑定这个全局变量,通过全局变量的current字段调用

      constructor(props) {
        super(props);
        this.d2 = React.createRef()
      }

<div ref={this.d2}>2</div>
 console.log(this.d2.current);

2.3 在标签ref属性绑定函数

在标签ref属性绑定函数,在函数中定义全局变量赋值,通过全局变量调用

    <h3 ref={ ele => this.myH3 = ele }></h3>
    this.myH3

注意:

1.在父组件中用ref获取子组件对象,必须保证子组件是类组件,函数式组件获取结果是undefined

2.父组件中子组件标签绑定ref属性,父组件使用ref获取子组件对象后,可以对子组件状态数据和函数执行调用和修改

总结

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

相关文章

  • 详解React 父组件和子组件的数据传输

    详解React 父组件和子组件的数据传输

    这篇文章主要介绍了React 父组件和子组件的数据传输的相关资料,帮助大家更好的理解和学习使用React,感兴趣的朋友可以了解下
    2021-04-04
  • React父子组件间的通信是怎样进行的

    React父子组件间的通信是怎样进行的

    这篇文章主要介绍了React中父子组件通信详解,在父组件中,为子组件添加属性数据,即可实现父组件向子组件通信,文章通过围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2023-03-03
  • React如何实现全屏监听Esc键

    React如何实现全屏监听Esc键

    这篇文章主要介绍了React如何实现全屏监听Esc键,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • React如何将组件渲染到指定DOM节点详解

    React如何将组件渲染到指定DOM节点详解

    这篇文章主要给大家介绍了关于React如何将组件渲染到指定DOM节点的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习下吧。
    2017-09-09
  • react hooks 计数器实现代码

    react hooks 计数器实现代码

    这篇文章主要介绍了react hooks计数器实现代码,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-08-08
  • React全局状态管理的三种底层机制探究

    React全局状态管理的三种底层机制探究

    近两年前端技术的发展如火如荼,大量的前端项目都在使用或转向 Vue 和 React 的阵营,由前端渲染页面的单页应用占比也越来越高,这篇文章主要给大家介绍了关于React全局状态管理的三种底层机制,需要的朋友可以参考下
    2021-09-09
  • 详解如何构建自己的react hooks

    详解如何构建自己的react hooks

    我们组的前端妹子在组内分享时谈到了 react 的钩子,趁此机会我也对我所理解的内容进行下总结,方便更多的同学了解。在 React 的 v16.8.0 版本里添加了 hooks 的这种新的 API,我们非常有必要了解下他的使用方法,并能够结合我们的业务编写几个自定义的 hooks。
    2021-05-05
  • react实现原生下拉刷新

    react实现原生下拉刷新

    这篇文章主要为大家详细介绍了react实现原生下拉刷新,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • useEffect支持async及await使用方式

    useEffect支持async及await使用方式

    这篇文章主要为大家介绍了useEffect支持async及await的使用方式示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07
  • react组件中过渡动画的问题解决

    react组件中过渡动画的问题解决

    这篇文章主要为大家介绍了react组件中过渡动画的问题解决,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-09-09

最新评论