Vue3/ Vue3中解决数据异步更新问题,可使用 nextTick( )

在Vue中,当数据变化时,DOM的更新不是立即同步的,而是被放入队列等待下一事件循环处理。为了解决这个问题,可以使用nextTick()方法或setTimeout来确保在DOM更新后执行某些操作。nextTick()会在DOM更新后立即回调,确保了数据和视图的一致性。
摘要由CSDN通过智能技术生成

问题:

问题就是我打印h1,最终更新出来的效果 页面是 5 , 控制台是 1 ,他们不是一致的,这样影响很大啊

 

-----------------------------------------------------------------------------------------------------------

解决问题:

使用 nextTick() 对打印进行包裹,或者时间 定时器 setTime 

底层原因: Vue中更改响应式状态时,最终DOM更新出来的不是同步生效的,而是Vue将他们缓存在一个队列中,因为只要侦听到数据变化 Vue将开启一个队列,并缓冲同一个事件循环内发生的所有数据变更,直到下一个事件循环开始才一起执行    直到下一个事件循环开始,才一起执行

nextTick()说明: 当数据执行了 在dom中渲染后,会自动执行该函数

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值