在Vue3中nextTick是如何保证顺序的

在Vue3中nextTick是如何保证顺序的

nextTick在Vue3的源码中的实现,从源码之没有看到控制的相关信息,那么必定是与参数p有关。追踪一下p相关的参数

const resolvedPromise = /*#__PURE__*/ Promise.resolve() as Promise<any>
let currentFlushPromise: Promise<void> | null = null

export function nextTick<T = void>(
  this: T,
  fn?: (this: T) => void
): <
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue3,nextTick和setTimeout都是用来处理异步任务的方法,但它们之间有一些不同之处。 nextTickVue提供的一个异步方法,它会在DOM更新之后执行回调函数。使用nextTick可以确保在更新完DOM后再执行某些操作,例如修改DOM属性或获取更新后的DOM信息。nextTick是基于Promise的,因此可以使用async/await语法或.then()方法来处理回调函数。nextTick执行顺序是在Vue实例的更新队列,因此可以确保在同一更新周期内的其他操作已完成。但需要注意的是,nextTick只会等待同一事件循环的更新完成,如果有多个nextTick回调函数,它们会在下一个事件循环依次执行。 而setTimeout是JavaScript提供的一个全局方法,它会在指定的时间后执行回调函数。setTimeout的执行顺序是在宏任务队列,因此可能会在DOM更新之前执行。setTimeout的时间参数是一个相对时间,单位是毫秒。使用setTimeout可以实现一些延迟执行的操作,但由于执行时间是不确定的,不能保证在DOM更新之后再执行。 所以,nextTick更适合处理Vue相关的异步操作,而setTimeout更适合一般的延时执行操作。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [前端面试题总结](https://blog.csdn.net/angrynouse/article/details/127075486)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值