详解 node/浏览器 事件循环中的微任务的优先级

关于事件循环机制,可以参考这篇文章

node 环境中的微任务

这里面补充一个,node 中微任务是有优先级的,常见的微任务有,其中 process.nextTick 的优先级最高,会优先执行,剩下的按照进入微任务队列的顺序,一次执行

  1. process.nextTick
    1. 此方法是 node 中将回调函数安排在当前执行栈的尾部,在I/O操作之后、事件循环的阶段之前执行,所以他的优先级最高!!
  2. promise
    1. 是 js 的原生对象,他的 .then 和 .catch 中注册的回调函数会被作为微任务。
    2. 注意 new promise 中的代码会当做同步任务执行,只有 then  catch 里面的才是微任务,并且在此之前一定要 resolve 或者 reject 改变promise 的状态,才能执行
  3. queueMicrotask
    1. node 中全局作用于中定义的函数,它接受一个函数作为参数,会在微任务队列中添加一个任务。

可以自己看一下下面代码的输出,注意需要在 node 环境下运行

console.log(1)
setTimeout(() => {console.log(2)new Promise((resolve) => {console.log(3)resolve()}).then(() => {console.log(4)})queueMicrotask(() => {console.log(5)})process.nextTick(() => {console.log(6)})console.log(7)}, 10);
process.nextTick(function () { console.log(8) })
new Promise((resolve) => {console.log(9)resolve()
}).then(() => {console.log(10)
})
queueMicrotask(() => {console.log(11)
})

输出结果如下:

浏览器环境中的微任务

浏览器环境中的微任务没有优先级的区别,都是按照进入队列的顺序执行的,浏览器中的微任务主要有:

  1. promise
  2. mutationObserver
    1. 当DOM结构发生变化时,注册的回调函数会以微任务的形式执行。
  3. queueMicrotask
    1. 在 window 上的一个全局的方案
    2. 想不到吧,浏览器也有这个方法,不要以为他是 node 里面才有的

复制下面代码到开发者工具中运行即可查看结果,注意找一个有 a 标签的网站

console.log(1)
new Promise((resolve) => {console.log(2)resolve()
}).then(() => {console.log(3)
})
// 监控一个元素
const node = document.querySelector('a')
const observer = new MutationObserver(() => {console.log(5)
})
observer.observe(node, {attributes: true
})
// 修改元素属性,用于监控
node.style.color = 'red'
queueMicrotask(() => {console.log(4)
})

结果如下,可以发现,这三个微任务是没有特殊的优先级的

加油,一切都是纸老虎,只要学会这点题目,事件循环统统都拿下

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/805212.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

pinia数据持久化

下载 pnpm i pinia 在 main.ts/js文件里面进行配置 import { createApp } from vue import App from ./App.vue import router from ./router // ① 引入createPinia方法从pinia import { createPinia } from pinia const app createApp(App) const pinia createPinia…

2024年第五届计算机视觉与信息技术国际会议(CVIT 2024)即将召开!

2024年第五届计算机视觉与信息技术国际会议(CVIT 2024)将于2024年8月16-18日在北京举行。CVIT 2024由北方工业大学主办,国内外的专家学者将齐聚一堂,共同分享最新的技术突破、研究方法和应用案例,共同推动计算机视觉与…

开启未来之门:Victoria VR 与 OpenAI 整合,引领 Web3 AI+AR 风潮

加密市场一直是科技创新的前沿阵地。虚拟现实(VR)技术和人工智能(AI)被认为是引领未来的重要技术之一,Web3 自然不会缺席这场足以改变人们生活方式的变革! 2月份,Apple Vision Pro 的发售迅速引…

Python爬虫网络实践:去哪儿旅游数据爬取指南

Python爬虫网络实践:去哪儿旅游数据爬取指南 在这个博客中,我们将探索如何使用 Python 来进行网络数据抓取,并以抓取旅游数据为例进行演示。我们将通过一个简单的示例来说明如何利用 Python 中的常用库进行网页抓取,从而获取旅游…

快速理解JS中的原型和原型链

快速理解JS中的原型和原型链 在我们学习JS的过程中,我们总会接触到一些词:“原型”,“原型链”。那么今天我就来带大家来学习学习原型和原型链的知识吧! 在开始之前,我们明确一下我们接下来想要学习的目标&#xff1a…

新型[datahelper@onionmail.org].datah 勒索病毒来袭:如何筑起安全防线?

在数字化时代,网络安全问题日益凸显,其中勒索病毒成为了一种非常严重的威胁。[datahelperonionmail.org].datah勒索病毒就是其中的佼佼者,它以其复杂的加密手段和恶劣的勒索行为,给用户带来了巨大的损失。本文将从病毒的运行机制、…

JS中的JSON(秒懂如何操作JSON)

目录 一、JSON介绍 1.概念 2.主要特点 3.优点 4.使用JSON的原因 使用 XML 使用 JSON 二、JSON语法 三、JSON使用 1.JSON的序列化 2.解析(parse) JSON 3.序列化(Stringify)JSON 四、JSON实例 1.用户信息 2.本地存储 五、JSON应用…

C++计算器类成员的实现

请编程完成如下任务: 根据类的定义,完成该类成员函数的实现。 编写main()函数,分别以默认值和输入的值num创建对象c1和c2,调用成员函数对c1的数据成员增加1,c2的数据成员减少1,然后分别输出c1和c2的数据成员。 函数接…

mapbox 工作问题暂时记录

mapbox 工作问题暂时记录 mapbox样式修改1.2.3.4. mapbox样式修改 1. mapbox直接用class名无法修改样式, 可以添加 :deep 来修改样式 2. map.value.getStyle().layers这行代码可以获取页面中所有图层,可以判断图层id来做相应操作 3. map.value.setLayoutProperty(layer.id…

ModuleNotFoundError: No module named ‘mlxtend‘

from mlxtend.plotting import plot_decision_regions 报错信息: ModuleNotFoundError: No module named mlxtend Jupyter和Spyder报错原因:因为anaconda下没有这个模块,需要安装mlxtend 解决方案: 1.打开anaconda(或终端) 2. 点击路径点…

Python爬虫之Scrapy框架基础

Scrapy爬虫框架介绍 文档 英文文档中文文档 什么是scrapy 基于twisted搭建的异步爬虫框架. scrapy爬虫框架根据组件化设计理念和丰富的中间件, 使其成为了一个兼具高性能和高扩展的框架 scrapy提供的主要功能 具有优先级功能的调度器去重功能失败后的重试机制并发限制ip使用次…

完全可定制的富文本编辑器:逻辑清晰,插件赋能 | 开源日报 No.218

ianstormtaylor/slate Stars: 28.8k License: MIT slate 是一个完全可定制的框架,用于构建富文本编辑器。 可以构建类似 Medium、Dropbox Paper 或 Google Docs 的富文本编辑器通过一系列插件实现所有逻辑,避免代码复杂度受到 Draft.js、Prosemirror 和…

1.grpc-教程(golang版)

目录 一、介绍 二、环境准备 三、Golang中使用grpc 1.编写protobuf文件 2.服务端 3.客户端 四、proto文件详解 1.proto语法 2.数据类型 基本数据类型 数组类型 map类型 嵌套类型 编写风格 3.多服务 4.多个proto文件 五、流式传输 1.普通rpc 2.服务器流式 …

基于SVM的时间序列预测模型matlab代码

整理了基于SVM的时间序列预测模型matlab代码, 包含数据集。采用了四个评价指标R2、MAE、MBE、MAPE对模型的进行评价。SVM模型在数据集上表现非常好。 Mean squared error 0.000180613 (regression) Squared correlation coefficient 0.995639 (regression) Mea…

【进阶六】Python实现SDVRPTW常见求解算法——自适应大邻域算法(ALNS)

基于python语言,采用经典自适应大邻域算法(ALNS)对 带硬时间窗的需求拆分车辆路径规划问题(SDVRPTW) 进行求解。 目录 往期优质资源1. 适用场景2. 代码调整2.1 需求拆分2.2 需求拆分后的服务时长取值问题 3. 求解结果4…

QT4和QT5区别

Qt4.8.7是Qt4的终结版本,是Qt4系列版本中最稳定最经典的。 1、 在pro文件中添加QT widgets模块,如果添加这个模块后,带有”QtGui/”的类一部分类型就不需要这个前缀了,可以直接用用本身的类名。 2、 将带有QTGui的类替换为QTWi…

信息收集-app,小程序,公众号,邮箱篇

*声明:*请勿利用文章内的相关技术从事非法测试,由于传播、利用此文所提供的信息而造成的任何直接或者间接的后果及损失,均由使用者本人负责,文章作者不为此承担任何责任。合法渗透,本文章内容纯属虚构,如遇…

【linux】sudo 与 su/su -之间的区别

一、区别 二、其他 大概是因为使用 su 命令或直接以 root 用户身份登录有风险,所以,一些 Linux 发行版(如 Ubuntu)默认禁用 root 用户帐户。鼓励用户在需要 root 权限时使用 sudo 命令。 然而,您还是可以成功执行 su…

反射+配置文件+抽象工厂模式

反射配置文件抽象工厂模式 文章目录 反射配置文件抽象工厂模式优化方案 优化方案 为了进一步优化代码,我们可以将产品类型与类名的映射关系存储在配置文件中,使得系统更易于管理和扩展。以下是在上述代码基础上添加配置文件的优化示例: 1.配…

快速熟悉torchdiffeq用法,从数理逻辑到完整案例【第二、三部分】

本系列文章板块规划 提示:以下内容仅为个人学习感悟,无法保证完全的正确和权威,大家酌情食用谢谢。 第一部分 torchdiffeq背后的数理逻辑 第二部分 torchdiffeq的基本用法 第三部分 trochdiffeq的升级用法 第四部分 torchdifffeq的案例和代码…