异步处理专题

异步处理专题

课前准备

  • 工具
    • 编辑器 VSCode
    • 浏览器 Chorme
  • 前置知识
    • ES6基础语法

课堂主题

  • 同步及异步概念
  • 方块运动的实现
  • promise的用法
  • then的返还值
  • Async 函数 和 await

课堂目标

理解并学会使用promise使用方式以及async 、await的使用

同步异步概念

  • js是单线程

    • 单线程:同一时间只能做一件事情
    • 为什么是单线程?
      • 为了避免复杂性
  • 同步和异步

    • 同步和异步是一种消息通知机制

      • 同步阻塞: A调用B,B处理获得结果,才返回给A。A在这个过程中,一直等待B的处理结果,没有拿到结果之前,需要A(调用者)一直等待和确认调用结果是否返回,拿到结果,然后继续往下执行。

      ​ 做一件事,没有拿到结果之前,就一直在这等着,一直等到有结果了,再去做下边的事

      • 异步非阻塞: A调用B,无需等待B的结果,B通过状态,通知等来通知A或回调函数来处理。

      ​ 做一件事,不用等待事情的结果,然后就去忙别的了,有了结果,再通过状态来告诉我,或者通过回调函数来处理。

在这里插入图片描述

异步处理方案

  • 回调

    • 通过回调函数来处理异步,容易造成回调地狱
      • 回调地狱:函数作为参数层层嵌套。回调地狱会导致代码可读性及可维护性变差。
  • 自定义事件

方块运动实现

  • 回调运动框架方块的运动

promise使用

  • ES6 Promise 对象

    • 两种参数:then的2个参数;onresolove 和 onreject;

    • ES6的Promise对象是一个构造函数,用来生成Promise实例。
      所谓Promise对象,就是代表了未来某个将要发生的事件(通常是一个异步操作)。
      它的好处在于,有了Promise对象,就可以将异步操作以同步操作的流程表达出来,避免了层层嵌套的回调函数

    • Promise对象的三种状态 pending 、resolve 和 reject

    • then 方法

    • then的返回值,会返回一个新的 Promise 对象, 但是状态会有几种情况:

      • then 的回调函数中没有返回值,then就会返回一个状态为: resolved 的 promise 对象
      • then 的回调函数返回值是 非 promise 的值, then就会返回一个状态为: resolved 的 promise 对象,另外会把返回值,传递给 下一个 then
      • then 的回调函数返回值是 promise 对象,then 就直接返回这个 promise 对象,具体的状态可以由我们自己定义,具体传递的值,也由我们自己定义
    • Promise 下的方法:resolve、reject、all、race、finally

async及await 改造promise

  • Async 函数 和 await 改造promise;

  • try及catch方法捕获错误

总结

  1. 同步和异步
  2. Promise 写法
  3. promise状态
  4. then的返还值
  5. Async 和 await 写法

下节课预告

Promise原理解析

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

无敌开心

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值