美文网首页
Promise对象

Promise对象

作者: 黑色的五叶草 | 来源:发表于2018-09-15 20:17 被阅读0次

promise 是什么

  • 按照用途来解释:
    1. 主要用于异步计算
    2. 可以将异步操作队列化,按照期望的顺序执行,返回符合预期的结果
    3. 可以在对象之间,传递和操作promise,以帮助我们处理队列

promise 的由来

  • javascript 包含大量的异步操作: 异步操作可以避免页面冻结
    1. javascript 为检查表单而生
    2. 创造它的首要目标是操作DOM
    3. nodeJs的出现:无堵塞,高并发
  • 异步:AB工作的完成顺序,和他们交付的完成时间顺序无关

异步操作的常见语法

  1. ajax请求:先调用外部函数,再执行内部回调函数,当外部函数执行完成,内部回调函数就会被执行


    image.png

异步的出现场景:

  • 浏览器中异步操作以事件为主
  • 回调主要出现在ajax请求和File API

经典示例:

  • 异步回调的问题:https://www.imooc.com/video/16611
    在异步回调过程中,无法正常使用try catch,只能通过return callback(err)函数的错误看出问题。(原因是:回调函数在执行的时候,已经和调用它的函数不在同一个堆栈中)

promise 入门

  • promise的使用:function(resolve, reject){} 传入的匿名函数称为执行器
    resolve(), reject() 调用后,会改变new promise实例的状态,
    实例的状态改变后,会调用then函数内部的处理函数


    image.png
  • promise详解:
    • promise是一个代理对象,它和原先要进行的操作并无关系
    • 它通过引入一个回调,避免更多的回调
  • promise状态


    image.png
    image.png
    image.png
  • 简单的promise实例:https://www.imooc.com/video/16613
console.log("here we go");
new Promise(resolve => {
    setTimeout(() => {
      resolve('hellow');
    }, 2000);
  }).then(value => {
      console.log(value + "word");
});
console.log("here we go");
new Promise(resolve => {
    setTimeout(() => {
      resolve('hellow');
    }, 2000);
  })
.then(value => {
      console.log(value);
      return new Promise(resolve => {
      setTimeout(() => {
        resolve('world');
      }, 2000);
  });
})  
.then(value => {
    console.log(value + "world");
})

(本帖参考自慕课网讲师:Meathill)

相关文章

  • Promise,async,await笔记

    Promise,async,await笔记 Promise 创建promise对象 Promise对象构造方法传入...

  • Promise then方法的链式调用

    返回的是非promise对象 优化:可能返回promise对象和非promise对象

  • ES6之promise(resolve与reject)

    一、 Promise.resolve() 有时需要将现有对象转为 Promise 对象,Promise.resol...

  • ES6-Promise对象 (下)

    ES6-Promise对象 (上) 1.Promise对象方法 (1)Promise.all(iterable);...

  • Promise对象原理解析

    Promise对象原理解析 ES6 原生提供了 Promise 对象。所谓 Promise,就是一个对象,用来传递...

  • ES6之promise(基本用法)

    一、promise的含义 Promise对象有以下两个特点。 (1)对象的状态不受外界影响。Promise对象代表...

  • Promise用法小结

    Promise 的含义 Promise对象有以下两个特点 :(1)对象的状态不受外界影响。Promise对象代表一...

  • 关于Promises

    一、名字 promise(首字母小写):一个对象,Promise的实例对象 Promise(首字母...

  • Promise

    Promise对象就是一个异步请求占位符对象 把异步请求封装在Promise对象中,Promise的构造函数传入一...

  • Promise

    Promise/A+ 英文 中文 实现Promise对象

网友评论

      本文标题:Promise对象

      本文链接:https://www.haomeiwen.com/subject/rmxtnftx.html