zoukankan      html  css  js  c++  java
  • ES6(Promise)

    Promise(异步编程的一种解决方案)

    1.什么是异步

    函数A,A去执行一个步骤,A执行再完执行B,这种执行方式实现有两种方式:

      1.回调 2.事件触发。Promise 区别于这两种方式

    2.Promise 的作用

    解决异步操作问题

    3.Promise 的基本用法

    见代码

    一.ES5中的回调(问题复杂时将难以解决,后期难以维护)

    (Ajax 过程)

    (先执行“执行”,1秒后执行 timeout1)

     ES6(Promise)写法

    先执行“执行2”,然后执行“timeout1”,最后执行“promise timeout2”

     ajax 返回 Promise 事例,执行下一步即 then 的函数体,resolve 执行,reject 停止

     then 表示 下一步

     二.串行过程(若中间出错,如何捕获错误)

     

    无错误,继续向下执行,故输出6

     

    catch 用来捕获错误,有错误,捕获到错误

    三.Promise 高级用法

    1.Promise.all(3张图片都加载完成再一起显示)

     1.添加图片

    2.显示图片

    3.遍历图片

    Promise.all 将多个 Promise 事例当做 一个 Promise 事例,当三个图片都触发后才会触发 Promise.all 对象,调用 then 方法

    4.结果

    只有当都加载完成才会显示

    2.(3个图片加载出一个就行,先到先得)

    1.添加图片

    2.显示图片

    3.遍历图片

    在多个状态中, 有一个事例率先改变,Promise.race的事例也会跟着改变,其他的都不能响应了

    4.结果

    只显示一个即可

  • 相关阅读:
    badblocks 检查硬盘是否有坏道
    IE兼容性开发的笔记
    Linux下设置ip和主机名进行绑定
    netty httpserver
    netty websocket协议开发
    OAuth2.0和SSO授权的区别
    window.location.href跳转问题2
    修改密码,验证两次输入是否相同,相同才能提交
    (2)集合 遍历set集合
    (1)集合 ---遍历map集合
  • 原文地址:https://www.cnblogs.com/jianghao233/p/8974932.html
Copyright © 2011-2022 走看看