首页 > web前端 > js教程 > 正文

javascript如何工作_它的执行机制是怎样的?

紅蓮之龍
发布: 2025-12-12 18:07:02
原创
669人浏览过
JavaScript执行机制核心是调用栈、任务队列和事件循环协同工作:调用栈执行同步代码(LIFO结构),任务队列分宏任务(如setTimeout)和微任务(如Promise.then),事件循环按“宏任务→微任务→渲染→下一宏任务”循环调度。

javascript如何工作_它的执行机制是怎样的?

JavaScript 是单线程、非阻塞、基于事件循环的脚本语言,它的执行机制核心在于 调用(Call Stack)任务队列(Task Queue)事件循环(Event Loop) 三者协同工作。

调用栈:同步代码的执行容器

JS 引擎执行同步代码时,会把函数调用逐层压入调用栈,执行完就弹出。它是后进先出(LIFO)结构,直观反映当前正在运行的函数链。

  • 全局代码先入栈,执行完毕后出栈
  • 遇到函数调用,函数体入栈;函数返回,立即出栈
  • 栈溢出(如无限递归)会导致 RangeError: Maximum call stack size exceeded

任务队列:分两类,处理异步回调

JS 把异步操作的回调按类型分进两个队列:

  • 宏任务队列(Macrotask Queue):包含 setTimeoutsetIntervalI/OUI 渲染script 标签加载等
  • 微任务队列(Microtask Queue):包含 Promise.then/catch/finallyqueueMicrotask()MutationObserver
  • 微任务优先级高于宏任务:每次宏任务执行完,会清空整个微任务队列,再取下一个宏任务

事件循环:持续协调执行节奏

事件循环是一个不断运行的机制,它按固定顺序检查和调度任务:

立即学习Java免费学习笔记(深入)”;

PLC编程入门基础知识 中文doc版
PLC编程入门基础知识 中文doc版

可编程序控制器,英文称Programmable Controller,简称PC。但由于PC容易和个人计算机(Personal Computer)混淆,故人们仍习惯地用PLC作为可编程序控制器的缩写。它是一个以微处理器为核心的数字运算操作的电子系统装置,专为在工业现场应用而设计,它采用可编程序的存储器,用以在其内部存储执行逻辑运算、顺序控制、定时/计数和算术运算等操作指令,并通过数字式或模拟式的输入、输出接口,控制各种类型的机械或生产过程。本平台提供PLC编程入门基础知识下载,需要的朋友们下载看看吧!

PLC编程入门基础知识 中文doc版 1
查看详情 PLC编程入门基础知识 中文doc版
  • 执行一个宏任务(比如主 script 或某个定时器回调)
  • 执行过程中遇到同步代码,进调用栈;遇到异步 API(如 setTimeoutnew Promise),注册回调并交由浏览器或 Node.js 环境托管
  • 宏任务结束后,立即执行所有已就绪的微任务(按注册顺序,一次性清空)
  • 然后渲染(浏览器环境),再取下一个宏任务,重复循环

例如:

console.log(1);
setTimeout(() => console.log(2), 0);
Promise.resolve().then(() => console.log(3));
console.log(4);
// 输出顺序:1 → 4 → 3 → 2
登录后复制

浏览器与 Node.js 的细微差异

两者都遵循事件循环模型,但阶段划分不同:

  • 浏览器没有明确的“阶段”概念,更关注宏/微任务的调度优先级
  • Node.js 将事件循环分为 6 个阶段(timers、pending callbacks、idle/prepare、poll、check、close callbacks),其中 process.nextTick() 比微任务还早执行(在当前操作末尾、下一阶段开始前)
  • 实际开发中,只要记住「微任务总在宏任务之间执行」,就能覆盖绝大多数场景

基本上就这些。理解调用栈、区分宏微任务、看清事件循环的调度节奏,你就掌握了 JS 执行机制的骨架。

以上就是javascript如何工作_它的执行机制是怎样的?的详细内容,更多请关注php中文网其它相关文章!

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号