深入理解JavaScript中的宏任务和微任务机制

概述

在JavaScript中,任务的执行分为两种:宏任务和微任务。宏任务和微任务是异步任务的一种处理方式,可以帮助我们合理地安排任务的执行顺序,避免出现项目中遇到的异步问题。

宏任务

宏任务是由浏览器内置的任务处理机制进行处理的,包括:加载事件(如load)、鼠标事件、输入事件、定时器事件等。当浏览器执行完当前宏任务后,才会去检查是否有待处理的微任务,如果有,就把所有的微任务全部执行。

微任务

微任务相对于宏任务而言,处理方式更加灵活,它们通过Promise进行管理。当Promise的状态变为resolved或rejected时,就会触发微任务。在当前任务执行结束后,会立即执行所有微任务,而不需要等待下一个宏任务执行。

如果在执行微任务时,又产生了新的微任务,会继续将其加入到微任务队列中,直到队列被清空。

示例说明

示例1

console.log("start");

setTimeout(function() {
  console.log("setTimeout");
}, 0);

Promise.resolve().then(function() {
  console.log("promise1");
}).then(function() {
  console.log("promise2");
});

console.log("end");

由于setTimeout是宏任务,Promise.resolve().then是微任务,程序的执行顺序如下:

start
end
promise1
promise2
setTimeout

示例2

console.log("start");

setTimeout(function() {
  console.log("setTimeout");
}, 0);

Promise.resolve().then(function() {
  console.log("promise1");

  Promise.resolve().then(function() {
    console.log("promise1.1");
  }).then(function() {
    console.log("promise1.2");
  });
}).then(function() {
  console.log("promise2");
});

console.log("end");

同样,setTimeout是宏任务,Promise.resolve().then是微任务,由此产生的嵌套Promise同样是微任务。程序执行顺序如下:

start
end
promise1
promise1.1
promise1.2
promise2
setTimeout

从上述两个示例可以看出,微任务的执行顺序是在同一个宏任务中先执行所有微任务,再执行宏任务。在宏任务执行时,如果产生了新的微任务,则会加入到微任务队列中,等待下一次宏任务执行。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:深入理解JavaScript中的宏任务和微任务机制 - Python技术站

(0)
上一篇 2023年6月11日
下一篇 2023年6月11日

相关文章

  • json字符串传到前台input的方法

    将JSON字符串传到前台input可以通过JavaScript的方式实现。主要分为两个步骤: 将JSON字符串赋值给JavaScript变量或对象 将变量或对象中的值赋值给input 下面分别详细说明这两个步骤。 将JSON字符串赋值给JavaScript变量或对象 首先,我们需要将JSON字符串转换为JavaScript对象。这可以通过JSON.parse…

    JavaScript 2023年5月27日
    00
  • Asp与JS的数组和字符串下标介绍

    Asp和JS都是常用的Web编程语言,数组和字符串是它们中非常重要的数据结构。下面来详细讲解一下Asp与JS的数组和字符串下标,以及使用示例。 数组下标 JS数组下标 JS数组下标从0开始,每个元素占据一个整数下标。可以使用以下语法创建JS数组:var arr = [val1, val2, …, valn];。其中,val1到valn为数组元素。 访问J…

    JavaScript 2023年5月27日
    00
  • JS简单测试循环运行时间的方法

    下面是关于JS简单测试循环运行时间的方法的攻略。 1. 背景 在编写JavaScript程序的过程中,有可能需要对程序进行性能测试,以确定代码的运行时间。本文将介绍如何使用JavaScript来测试循环运行时间的方法。 2. 代码示例 示例 1: 下面就是一个通过比较时间差来测试循环执行时间的示例代码: // 定义一个需要测试运行时间的函数 function…

    JavaScript 2023年5月27日
    00
  • JavaScript设置获取和设置属性的方法

    JavaScript中的对象都有属性,这些属性通常指的是对象的特性。获取和设置属性是JavaScript中最基础的操作之一,它是我们在实际开发中经常会用到的操作。 获取属性的值 JavaScript中有很多方式可以获取属性的值,例如使用.操作符或[]操作符来获取属性的值。使用.操作符获取属性的值,语法如下: 对象.属性名 例如: var person = {…

    JavaScript 2023年6月11日
    00
  • JavaScript高级程序设计 扩展–关于动态原型

    关于JavaScript高级程序设计中的扩展——动态原型,我来详细解释一下。 动态原型 JavaScript 是一门基于原型继承的语言,原型链决定了对象如何继承属性和方法。原型是 JavaScript 对象中一个非常重要的概念,用于实现对象的继承,从而节省大量的代码。 动态原型模式是一种在同时使用构造函数和原型的情况下,可以向原型中添加方法的方法。如下所示:…

    JavaScript 2023年5月27日
    00
  • 基于BootstrapValidator的Form表单验证(24)

    下面是一份详细的“基于BootstrapValidator的Form表单验证(24)”的完整攻略。 简介 在Web开发中,表单验证是非常重要的一部分,可以帮助我们保证用户输入的数据的准确性、有效性和安全性。BootstrapValidator是一个快速且易于使用的jQuery表单验证插件,它可以通过简单的配置和调用API即可实现表单验证。本攻略将带你一步步完…

    JavaScript 2023年6月10日
    00
  • JavaScript中实现sprintf、printf函数

    在JavaScript中,有时候需要格式化字符串输出,针对此需求,可以使用sprintf、printf函数来实现。 sprintf函数的实现 sprintf函数的作用是将指定的格式化字符串输出到一个字符串中。JavaScript中没有原生实现sprintf函数的方法,但是可以通过自定义实现函数来达到此目的。 下面是一个使用sprintf函数实现字符串格式化输…

    JavaScript 2023年5月27日
    00
  • js+ajax实现的A*游戏路径算法整理

    关于“js+ajax实现的A*游戏路径算法整理”的完整攻略,以下是详细介绍(注意,为了方便阅读,带有代码块的内容使用了代码语法高亮): 什么是A*算法? A*算法是一种基于图形、搜索和启发式运算的寻路算法,通常用于从起点到目标点的最优路径搜索。 A*算法的要点 A*算法将费用(距离、代价)与启发式函数两者结合,来评估当前节点到目标点路径的可能代价大小。其中启…

    JavaScript 2023年5月28日
    00
合作推广
合作推广
分享本页
返回顶部