AJAX进阶(重点)

目录

◆ 同步代码和异步代码

◆ 回调函数地狱和 Promise 链式调用

什么是回调函数地狱?

Promise - 链式调用

什么是Promise链式调用?

Promise 链式应用 (重点)

◆ async 和 await 使用

async函数和await_捕获错误 

◆ 事件循环-EventLoop(重点)

为什么要学习事件循环?

什么是事件循环? 

事件循环 - 执行过程(重点)

事件循环 - 练习 

宏任务与微任务 (重点)

事件循环 - 经典面试题 

◆ Promise.all 静态方法


◆ 同步代码和异步代码

什么是同步代码,什么是异步代码?

同步代码:

AJAX进阶(重点)_第1张图片

异步代码:

 

同步代码:逐行执行,需原地等待结果后,才继续向下执行 

异步代码:调用后耗时,不阻塞代码继续执行(不必原地等待),在将来完成后触发一个回调函数

例子:回答打印数字的顺序是什么? 

AJAX进阶(重点)_第2张图片

打印结果:1,4,2 点击按钮一次就打印一次 3 

异步代码接收结果:使用回调函数

◆ 回调函数地狱和 Promise 链式调用

什么是回调函数地狱?

需求:展示默认第一个省,第一个城市,第一个地区在下拉菜单中

概念:在回调函数中嵌套回调函数,一直嵌套下去就形成了回调函数地狱

缺点:可读性差,异常无法捕获,耦合性严重,牵一发动全身

AJAX进阶(重点)_第3张图片

AJAX进阶(重点)_第4张图片 

总结:简单讲。回调函数地狱就是在回调函数中嵌套回调函数,进而导致代码耦合度高,异常难以捕获

Promise - 链式调用

什么是Promise链式调用?

概念:依靠 then() 方法会返回一个新生成的 Promise 对象特性,继续串联下一环任务,直到结束

细节:then() 回调函数中的返回值,会影响新生成的 Promise 对象最终状态和结果 

好处:通过链式调用,解决回调函数嵌套问题

AJAX进阶(重点)_第5张图片

Promise 链式应用 (重点)

目标:使用 Promise 链式调用,解决回调函数地狱问题

做法:每个 Promise 对象中管理一个异步任务,用 then 返回 Promise 对象,串联起来

AJAX进阶(重点)_第6张图片 





  
  
  
  Promise链式调用_解决回调地狱



  
省份: 城市: 地区:

 

总结: 

1. 什么是 Promise 的链式调用?

  • ➢ 使用 then 方法返回新 Promise 对象特性,一直串联下去

2. then 回调函数中,return 的值会传给哪里?

  • ➢ 传给 then 方法生成的新 Promise 对象

3. Promise 链式调用有什么用?

  • ➢ 解决回调函数嵌套问题 

◆ async 和 await 使用

定义:

概念: 在 async 函数内,使用 await 关键字取代 then 函数,等待获取 Promise 对象成功状态的结果值

示例:

AJAX进阶(重点)_第7张图片 

 简单来说,当函数使用了async关键字,可以使用await关键字讲函数内的异步函数转化成同步函数

async函数和await_捕获错误 

AJAX进阶(重点)_第8张图片

AJAX进阶(重点)_第9张图片 

◆ 事件循环-EventLoop(重点)

  • 为什么要学习事件循环?

掌握 JavaScript 是如何安排和运行代码的

AJAX进阶(重点)_第10张图片

什么是事件循环? 

概念:

原因:JavaScript 单线程(某一刻只能执行一行代码),为了让耗时代码不阻塞其他代码运行,设计了事件循环模型 

事件循环 - 执行过程(重点)

定义:执行代码和收集异步任务的模型,在调用栈空闲时,反复调用任务队列里回调函数的执行机制,就叫事件循环

AJAX进阶(重点)_第11张图片

总结:

1. 什么是事件循环?

  • ➢ 执行代码和收集异步任务,在调用栈空闲时,反复调用任务队列里

回调函数执行机制
2. 为什么有事件循环?

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

3. JavaScript 内代码如何执行?

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

事件循环 - 练习 

使用模型,分析代码执行过程

AJAX进阶(重点)_第12张图片

宏任务与微任务 (重点)

ES6 之后引入了 Promise 对象, 让 JS 引擎也可以发起异步任务

异步任务分为:

宏任务:由浏览器环境执行的异步代码

例子:

AJAX进阶(重点)_第13张图片

微任务:由 JS 引擎环境执行的异步代码

例子:

AJAX进阶(重点)_第14张图片

Promise 本身是同步的,而then和catch回调函数是异步的 

使用图解-分析代码执行顺序

AJAX进阶(重点)_第15张图片

 

JS代码的执行流程:script代码块-》代码块里的同步任务-》微任务-》宏任务 

AJAX进阶(重点)_第16张图片

事件循环 - 经典面试题 

AJAX进阶(重点)_第17张图片

答案:1756234 

总结:

1. 什么是宏任务?

  • ➢ 浏览器执行的异步代码
  • ➢ 例如:JS 执行脚本事件,setTimeout/setInterval,AJAX请求完成事件,用户交互事件

2. 什么是微任务?

  • ➢ JS 引擎执行的异步代码
  • ➢ 例如:Promise对象.then()的回调

3. JavaScript 内代码如何执行?

  • ➢ 执行第一个 script 脚本事件宏任务,里面同步代码
  • ➢ 遇到 宏任务/微任务 交给宿主环境,有结果回调函数进入对应队列
  • ➢ 当执行栈空闲时,清空微任务队列,再执行下一个宏任务,从1再来

 

◆ Promise.all 静态方法

概念:合并多个 Promise 对象,等待所有同时成功完成(或某一个失败),做后续逻辑

AJAX进阶(重点)_第18张图片

语法: 

AJAX进阶(重点)_第19张图片

案例:

需求:同时请求“北京”,“上海”,“广州”,“深圳”的天气并在网页尽可能同时显示

AJAX进阶(重点)_第20张图片

AJAX进阶(重点)_第21张图片 





  
  
  
  Promise的all方法



  

     

    你可能感兴趣的:(AjAX,ajax,前端,javascript)