关于react useState不能动态监听某一个属性变化的问题

业务需求

1.使用echarts动态展示数据时可以动态的切换单位

我开始的实现思路是:
获取已经存放数据的option,将里面的数据一个一个取出来进行计算之后,重新放入option,以下是代码:

const [option,setOption] = useState({});
const series  = option.series.map(item =>{
          let temp = []
          item.data.map(item =>{
              let sum = i / value
              temp.push(temp)
              return item;
          })
        setOption({...option,series})

但是最后uesState并不能监听到option局部属性的变化,之后我又尝试了使用useRef去使用current获取当前的option,以下是React Developer Tools中option中的series中的数据,可以很明显的看到其中的data并没有实时更新,这个是因为和react的异步调用有关系,他是异步的,所以并不能实时的监听到动态的变化
在这里插入图片描述

解决办法:

之所以没有监听到变化,实际上就是因为没有动态的改变它的内存地址,所以他没有监听到变化,所以实现思路就是改变他的内存地址

  const totalResult = JSON.parse(JSON.stringify(option))

将原来的option转换成字符串,再将字符串转换成对象,以改变对象的方式去改变他的内存地址,这样就可以监听到他的动态变化,然后再对内部属性进行处理

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值