当前位置: 首页 > news >正文

vue的nextTick是下一次事件循环吗

如题,nextTick的回调是在下一次事件循环被执行的吗?

是不是下一次事件循环取决于nextTick的实现,如果是用的微任务,那么就是本次事件循环;否则如果用的是宏任务,那么就是下一次事件循环。

我们看下Vue3中nextTick的源码:

export function nextTick<T = void, R = void>(this: T,fn?: (this: T) => R,
): Promise<Awaited<R>> {const p = currentFlushPromise || resolvedPromisereturn fn ? p.then(this ? fn.bind(this) : fn) : p
}

可以看到它的实现就是使用Promise,所以妥妥的微任务,所以nextTick的回调一定是在当前事件循环的微任务阶段被执行的,而不是下一次事件循环

但是在之前的版本中,nextTick可能会使用setTimeout,源码我们就不贴了。既然使用了setTimeout,就是宏任务,那自然就是下一次事件循环了。

可能是因为nextTick这个名字已经深入人心,所以Vue并没有要更改的意思。

那么接下来问题来了!

既然nextTick是本次事件循环,也就是说页面还没有渲染,那么为什么nextTick的回调可以获取到计算后的DOM结果呢?

这个问题真的困扰了我一段时间?

然后我做了个实验,实验代码如下:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title></head>
<body><button onclick="doClick()">点击</button><h1>Hello</h1>
<script>function doClick() {document.querySelector('h1').innerText = 'Hi'alert(document.querySelector('h1').innerText)}
</script>
</body>
</html>

这是纯HTML代码,不是Vue的代码。

你猜一下点击完按钮会发生什么?

结果如下:
在这里插入图片描述
点击确定后:
在这里插入图片描述
我们来解释一下为什么是这个结果。

  • 首先我们点击按钮,触发了doClick事件,这是一个宏任务。
  • 我们在这个宏任务中修改了h1的元素内容为Hi,这是一个同步操作,所以DOM的计算是立刻发生的。因此我们接下来通过alert正确打印了更新后的内容Hi。
  • 但是alert阻止了浏览器的渲染,所以页面看到的还是Hello。
  • 当我们点击确定之后,宏任务doClick执行结束,浏览器开始渲染,页面的内容也被更新成了Hi。

总结下来就一句话,就是DOM的计算是立刻发生的,所以可以立刻获取到结果,但是渲染是异步的

回到nextTick,nextTick为啥能获取到计算后的DOM结果呢?

原因就是nextTick是在异步更新队列之后执行,此时真实的DOM操作已经执行了,所以就可以读取到计算后的DOM结果了。

跟nextTick是不是下一次事件循环没有关系,跟浏览器是不是已经渲染了没有关系。

http://www.lryc.cn/news/413554.html

相关文章:

  • 5.4.软件工程-系统设计
  • Apache Kylin与BI工具集成:数据可视化实战
  • 通过idea图形化界面就能push到github流程
  • C语言初阶(10)
  • Javaweb用过滤器写防跳墙功能和退出登录
  • 小试牛刀-Telebot区块链游戏机器人(TS升级)
  • MySQL:Prepared Statement 预处理语句
  • Java:Thread类以及线程状态
  • 如何通过前端表格控件实现自动化报表?
  • Upload-labs靶场Pass01-Pass21全解
  • 使用openpyxl库对Excel数据有效性验证
  • 【算法】浅析深度优先搜索算法
  • 鸿蒙系统开发【ASN.1密文转换】安全
  • 【期末复习】软件质量保证与测试
  • CTFHub——XSS——反射型
  • docker 部署 libreoffice
  • 预测各种开发语言的市场占比
  • mybatisplus 通用字段自动赋值与更新
  • 图像生成中图像质量评估指标—FID介绍
  • uniapp全局分享功能实现方法(依赖小程序右上角的分享按钮)
  • Redis中BigKey的判定查找建议
  • Swift-语法基础
  • 面向对象进阶:多态、内部类、常用API
  • 寸(英寸)、码、斤、公顷等日常中大概的换算单位你清楚吗
  • Python面试宝典第26题:最长公共子序列
  • 接口测试学习笔记2
  • vue3修改带小数点的价格数字:小数点的前后数字,要分别显示成不同颜色和大小!已经封装成组件了!
  • JVM(Java虚拟机) - JVM内存分配与内存管理
  • Linux中vim的基本介绍和使用
  • 宝塔面板上,安装rabbitmq