AJAX: 事件循环(举例细论)

简介: AJAX: 事件循环(举例细论)

概念:执行任务和收集异步任务,在调用栈空闲时,反复调用任务队列里回调函数的一种执行机制


原因:JavaScript 是单线程的,为了不阻塞 JS 引擎,设计执行代码的模型


JS内代码如何执行:


执行同步代码,遇到异步代码就交给宿主浏览器环境执行。异步有了结果之后,把回调函数放到任务队列中排队,当调用栈空闲后,反复调用任务队列里的回调函数


案例:

console.log(1)
setTimeout(() => {
  console.log(2)
}, 0)
console.log(3)
setTimeout(() => {
  console.log(4)
}, 2000)
console.log(5)

执行过程:

ac32f780781945e2bbb8c8756fb50be6.png

1-JS引擎把console.log(1)放入调用栈中,执行后弹出


2-JS引擎发现setTimeout(…, 0) 是异步代码,于是将它放入宿主环境(浏览器)中,执行setTimeout(…, 0),完成后放入任务队列中


3-JS引擎把console.log(3)放入调用栈中,执行后弹出


4-JS引擎发现setTimeout(…, 2000) 是异步代码,于是将它放入宿主环境(浏览器)中,执行setTimeout(…, 2000)要等待2s,完成后放入任务队列中


5-JS引擎把console.log(5)放入调用栈中,执行后弹出


6-此时,JS的调用栈空闲,调用任务队列中的回调函数,先调用setTimeout(…, 0)中的回调函数console.log(2) ,执行后出栈。此时,JS的调用栈再次空闲,它会保持监视任务队列情况。当2s到时,会调用setTimeout(…, 2000)中的回调函数console.log(4) ,执行后出栈。


参考:AJAX-Day04-07.事件循环_哔哩哔哩_bilibili


相关文章
|
8月前
|
XML 前端开发 JavaScript
Ajax运行原理
Ajax运行原理
75 0
|
4月前
|
前端开发 JavaScript
AJAX的同步异步编程
AJAX的同步异步编程
27 0
|
9月前
|
小程序 前端开发
|
XML 前端开发 JavaScript
详细解析JavaScript的Ajax之同步和异步的区别
详细解析JavaScript的Ajax之同步异步的区别 博客整理到这里基本上JavaScript的初级知识就整理完了,现在我们来说一下看JavaScript的最后一个知识点——Ajax。 (Asynchronous Javascript And XML) 即异步 JavaScript 和 XML,一种创建交互式、快速动态网页应用的网页开发技术,无需重新加载整个网页的情况下,能够更新部分网页的技术。 1.同步和异步 首先我们先来分析一下JavaScript的中的同步和异步的区别。 同步就是调用某个内容时,调用方得等待这个调用返回结果才能继续往后执行。(期间不可以执行其他的命令)。如图:
详细解析JavaScript的Ajax之同步和异步的区别
|
Web App开发 XML 存储
【AJAX】对于AJAX 解析已经XMLHttpRequest对象对于异步的操作等等在项目中的体验
【AJAX】对于AJAX 解析已经XMLHttpRequest对象对于异步的操作等等在项目中的体验
【AJAX】对于AJAX 解析已经XMLHttpRequest对象对于异步的操作等等在项目中的体验
|
前端开发 JavaScript 数据格式
学习AJAX必知必会(4)~JQuery发送Ajax请求、ajax使用fetch函数(返回值是Promise对象)
学习AJAX必知必会(4)~JQuery发送Ajax请求、ajax使用fetch函数(返回值是Promise对象)
230 0
|
Nacos 容器
AsyncContext异步请求的用法
AsyncContext异步请求的用法
AsyncContext异步请求的用法
|
XML JSON 前端开发
浅析ajax原理与用法
浅析ajax原理与用法 1 ajax原理 Ajax(Asynchronous JavaScript and XML (异步的JavaScript和XML)),是一种快速创建动态网页的技术,目的 是显示动态局部刷新.
|
前端开发 数据格式 JSON