react hook使用useState()更新状态(state)异步导致不能及时读取更新之后的数据

1、场景描述

我在更新一个状态之后要立马用这个状态去更新其他状态
我的源代码

const onChange = (nextTargetKeys: any) => {
//更新状态
    setTargetKeys(nextTargetKeys);
    let v = 0;
    let n = 0;
    let g = 0;
    //立马使用
   targetKeys.forEach((item: number, index) => {
      v += mockData[item].itemVolume;
      n += mockData[item].itemNw;
      g += mockData[item].itemGw;
    });
       setTopData({ v: Number((v/1000000).toFixed(4)), n: n, g: g });
  };

如果是vue,这里是没有问题的 ,但是这是react~这里的数据还没更新,取到的还是旧数据
这里加个setTimeout延迟执行就是新的数据。这是为什么了?
原因:
vue是同步更新状态,异步视图,当状态变化是阻塞更新完成之后执行后继逻辑,
react是异步更新状态,setState 是异步方法,所以不会阻塞!

2、处理办法:

添加一个 副作用(useEffect()

  useEffect(()=>{
    let v = 0;
    let n = 0;
    let g = 0;
    targetKeys.forEach((item: number, index) => {
      v += mockData[item].itemVolume;
      n += mockData[item].itemNw;
      g += mockData[item].itemGw;
      console.log(v)
    });
    setTopData({ v: Number((v/1000000).toFixed(4)), n: n, g: g });
     },[targetKeys])

顺便发表感受,还是vue的状态更新直接、简便!
ok!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值