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


相关文章
|
XML 前端开发 JavaScript
Ajax运行原理
Ajax运行原理
100 0
|
2月前
|
XML 前端开发 JavaScript
ajax运行原理
AJAX(Asynchronous JavaScript and XML)是一种使网页能够在不重新加载整个页面的情况下与服务器异步通信的技术。尽管名字中有“XML”,但它支持多种数据格式,如JSON、HTML和纯文本。用户行为触发AJAX请求后,通过创建`XMLHttpRequest`对象或使用现代浏览器中的`fetch` API来配置并发送HTTP请求。请求完成后,可以通过回调函数处理服务器返回的数据,更新网页内容。现代JavaScript推荐使用更简洁强大的`fetch` API来实现AJAX功能,广泛应用于动态网页和单页应用中,提升用户体验。
|
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对象对于异步的操作等等在项目中的体验
121 0
【AJAX】对于AJAX 解析已经XMLHttpRequest对象对于异步的操作等等在项目中的体验
|
XML 前端开发 JavaScript
简述Ajax,以及使用原生js书写Ajax案例
简述Ajax,以及使用原生js书写Ajax案例
152 0
|
Nacos 容器
AsyncContext异步请求的用法
AsyncContext异步请求的用法
AsyncContext异步请求的用法
|
前端开发 JavaScript 数据格式
学习AJAX必知必会(4)~JQuery发送Ajax请求、ajax使用fetch函数(返回值是Promise对象)
学习AJAX必知必会(4)~JQuery发送Ajax请求、ajax使用fetch函数(返回值是Promise对象)
250 0
|
XML JSON 前端开发
浅析ajax原理与用法
浅析ajax原理与用法 1 ajax原理 Ajax(Asynchronous JavaScript and XML (异步的JavaScript和XML)),是一种快速创建动态网页的技术,目的 是显示动态局部刷新.
|
前端开发 数据格式 JSON