当前位置: 首页 > 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是不是下一次事件循环没有关系,跟浏览器是不是已经渲染了没有关系。

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 新华三H3CNE网络工程师认证—路由基础
  • springboot+vue+mybatis汽车租赁管理+PPT+论文+讲解+售后
  • AI与PS:技术革命下的设计工具比较
  • 数学建模之数据分析【二】:什么是数据?
  • C语言中整数类型及其类型转换
  • 用Java手写jvm之模拟方法调用指令invokexxx和方法返回指令xreturn
  • 深入解析 Nginx 反向代理:配置、优化与故障排除
  • Visual Studio vs VSCode:深入剖析两款开发工具的优劣与应用场景
  • 网络安全 - 应急响应检查表
  • 【基础算法模板】堆
  • Linux OOM Killer详解
  • pytest-bdd 行为驱动自动化测试
  • 防止老年痴呆的小学题
  • DLMS/COSEM中的信息安全:加密算法(下)2
  • 批发行业进销存-登录适配 android 横竖屏幕 源码CyberWinApp-SAAS 本地化及未来之窗行业应用跨平台架构
  • 【RocksDB】TransactionDB源码分析
  • Babel配置的不完全指南
  • - C#编程大幅提高OUTLOOK的邮件搜索能力!
  • es6--symbol
  • input实现文字超出省略号功能
  • Java面向对象及其三大特征
  • js ES6 求数组的交集,并集,还有差集
  • LeetCode29.两数相除 JavaScript
  • MobX
  • PAT A1050
  • Python打包系统简单入门
  • React-Native - 收藏集 - 掘金
  • 基于webpack 的 vue 多页架构
  • 技术攻略】php设计模式(一):简介及创建型模式
  • 入门级的git使用指北
  • 深度学习入门:10门免费线上课程推荐
  • 探索 JS 中的模块化
  • 微信开源mars源码分析1—上层samples分析
  • scrapy中间件源码分析及常用中间件大全
  • ​油烟净化器电源安全,保障健康餐饮生活
  • #Linux(权限管理)
  • #NOIP 2014#day.2 T1 无限网络发射器选址
  • #我与Java虚拟机的故事#连载11: JVM学习之路
  • #知识分享#笔记#学习方法
  • (html5)在移动端input输入搜索项后 输入法下面为什么不想百度那样出现前往? 而我的出现的是换行...
  • (vue)页面文件上传获取:action地址
  • (读书笔记)Javascript高级程序设计---ECMAScript基础
  • (二)原生js案例之数码时钟计时
  • (生成器)yield与(迭代器)generator
  • (一)WLAN定义和基本架构转
  • (转)关于如何学好游戏3D引擎编程的一些经验
  • (轉貼) UML中文FAQ (OO) (UML)
  • **PHP二维数组遍历时同时赋值
  • *Django中的Ajax 纯js的书写样式1
  • .NET C# 配置 Options
  • .NET Compact Framework 多线程环境下的UI异步刷新
  • .net core 6 集成和使用 mongodb
  • .NET MVC 验证码
  • .NET设计模式(8):适配器模式(Adapter Pattern)
  • .NET中使用Protobuffer 实现序列化和反序列化