react useState异步问题

1.

useState执行后 不能立马拿到新的数据,下次更新绘图就可以拿到了
然后当执行完第一次render时候,比如去点击按钮啥的执行某个方法这个时候就可以拿到数据了
例子:
const UseState = () => {
// 函数组件中没有this
const [count, setCount] = useState(0)

const add = () => {
let newCount = count
console.log(‘value1’, count); // 0
setCount( newCount+= 1)
console.log(‘value2’, count); // 0
query()
}

const query = () => {
console.log(‘query函数中:’, count); // 0
}
return (


{count}


增加

)
}
在这里插入图片描述
解决方法:
1)可以将count的新值通过函数传参的方式传入query函数;
// 改写add和query函数;

const add = () => {
let newCount = count
console.log(‘value1’, count);
setCount( newCount+= 1)
console.log(‘value2’, count);
query(newCount)
}
const query = (count) => {
console.log(‘query函数中:’, count);
}
在这里插入图片描述
2)在useEffect中调用query函数,因为在useEffect中,组件dom已经更新完毕,可以拿到count的最新值;(缺点:每次count值改变,都会触发useEffect,从而执行query函数;)
// 组件每次渲染之后执行的操作,执行该操作时dom都已经更新完毕
useEffect(()=>{
// 1、可在此处拿到count更新后的值
console.log(‘value3’, count);
query()
}, [count])

const add = () => {
let newCount = count
console.log(‘value1’, count);
setCount( newCount+= 1)
console.log(‘value2’, count);
}
const query = () => {
console.log(‘query函数中:’, count);
}
在这里插入图片描述
3)通过useRef()定义一个可变的ref变量,通过current属性保存count可变值,从而在count更新后,通过ref的current属性拿到更新后的count值;注意:调用query函数时需要加上setTimeout()进行调用;

// 定义一个可变的countRef对象,该对象的current属性被初始化为传入的参数count;
const countRef = useRef(count)

// 在countRef.current属性中保存一个可变值count的盒子;
countRef.current = count

const add = () => {
let newCount = count
console.log(‘value1’, count);
setCount( newCount+= 1)
console.log(‘value2’, count);
setTimeout(() => query(), 0);
}

const query = () => {
console.log(‘query函数中:’, countRef.current);
}
在这里插入图片描述

2.

下次更新绘图就可以拿到了
然后当执行完第一次render时候,比如去点击按钮啥的执行某个方法这个时候就可以拿到新的数据了
例子:
const [init, setInit] = useState()
const inti = async () => {
setInit(true)
};
useEffect(() => {
init();
}, []);
const fn = async () => {
console.log(881, init);
};

相关推荐

  1. C# 异步问答

    2023-12-21 08:24:01       30 阅读
  2. SPI异步传输使用DMA 问题

    2023-12-21 08:24:01       66 阅读
  3. 解决小程序的异步请求问题

    2023-12-21 08:24:01       28 阅读
  4. 分享遇到的异步问题合集

    2023-12-21 08:24:01       24 阅读
  5. 【级联下拉选项请求异步问题解决】

    2023-12-21 08:24:01       57 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-21 08:24:01       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-21 08:24:01       100 阅读
  3. 在Django里面运行非项目文件

    2023-12-21 08:24:01       82 阅读
  4. Python语言-面向对象

    2023-12-21 08:24:01       91 阅读

热门阅读

  1. ubuntu18 安装 cmake v3.26.1

    2023-12-21 08:24:01       55 阅读
  2. php版本编译以及扩展包安装

    2023-12-21 08:24:01       66 阅读
  3. 深入探索 Rust 中的 Panic 机制

    2023-12-21 08:24:01       41 阅读
  4. 【其他】数字孪生简介

    2023-12-21 08:24:01       68 阅读
  5. 剑指offer题解合集——Week1day5

    2023-12-21 08:24:01       68 阅读
  6. pytorch RNN

    2023-12-21 08:24:01       43 阅读