在理解promise的使用之前,首先要理解js语言的运行环境是单线程的,也就是说一次只能完成一个任务,也就是一条流水线,如果有多个任务就必须排队,前面一个任务完成,再执行后面一个任务,以此类推。这与java的多线程环境截然不同,所以要加以区分。

1、对于js同步和异步,在这里需要加以备注一下:

我们可以简单的理解为:可以改变程序执行顺序的操作就可以看成为异步操作。其实异步和同步的差别很简单,就在于这条流水线上各个流程的执行顺序不同。最基础的异步是setTimeout和setInterval函数如图示例所示:

而执行顺序为

也就是说,“王一”和“刘五”所在的流水线为同步,即在主线程上执行的任务,,而setTimeout函数为异步任务,不进入主线程,而进入“任务队列”。程序先执行同步里的内容,执行完毕,“任务队列”开始通知主线程,请求执行任务,该任务才会进入主线程来执行。

而“任务队列”是一个事件的队列,IO设备完成一项任务,就在“任务队列”中添加一个事件,表示相关的异步任务可以进入主线程了,主线程读取‘任务队列’,就是读取里面就哪些事件。‘任务队列’中的事件除了IO设备的事件以外,还包括用户产生的一些事件(比如鼠标点击、页面滚动等)。

异步任务必须指定回调函数,当主线程开始执行异步任务,就是执行相应的回调函数。例如ajax的success,complete,error也都指定了各自的回调函数,这些函数就会加入任务队列中,等待执行。

2、promise

利用promise可以将异步操作以同步操作的流程表达出来,避免了层层嵌套的回调函数。此外,promise对象提供统一的接口,使得控制异步操作更加容易。

但注意promise无法取消,一旦建立就会立即执行,无法中途取消。而且,如果不设置回调函数,promise内部抛出的错误不会反映到外部。当处于Pending状态时,无法得知进展到哪一个阶段。

1)promise有三个状态:

Pending-promise的初始状态,等到任务完成或是被拒绝;Resolved-执行完成并且成功的状态;Rejected-执行完成并且失败的状态。此三个状态不能相互逆转。

2)promise对象必须实现then方法,可以说then是promise的核心,而且then方法必须返回一个promise对象,同一个promise对象可以注册多个then方法,并且回调的执行顺序和他们注册的顺序一致。

3)then方法接收两个回调函数,他们分别是成功时的回调和失败时的回调。

value值表示的是异步执行成功之后在promise函数中获取的值,不确切的说就是可以获取该函数的私有变量,将promise的值获取过来之后在then中可以实现值的相应应用。

以下示例表示promise的不可逆性和链式调用:

js promise的用法相关推荐

  1. js promise then 用法详解

    Promise 是抽象的异步处理对象 构造方法: let promies = new Promise((resolve, reject) => {resolve(); //异步处理 }); Pr ...

  2. js——promise用法

    .1.promise基本用法 <script>const promise =new Promise((resolve,reject)=>{console.log(1);resolve ...

  3. 【ES6】JS类的用法class

    [ES6]JS类的用法class 一.概述 二.构造函数constructor 三.静态方法与静态变量 查看更多ES6教学文章: 参考文献 引言:由于JS之前一直没有特有的class来定义类的语法,E ...

  4. JS - Promise使用随笔

    一.promises相关概念 promises 的概念是由 CommonJS 小组的成员在 Promises/A 规范中提出来的. 1,then()方法介绍 根据 Promise/A 规范,promi ...

  5. JavaScript异步与Promise基本用法(resolve与reject)

    Promise解决的问题 相信每个前端都遇到过这样一个问题,当一个异步任务的执行需要依赖另一个异步任务的结果时,我们一般会将两个异步任务嵌套起来,这种情况发生一两次还可以忍,但是发生很多次之后,就形成 ...

  6. js Promise学习

    js Promise promise入参为两个 成功时的执行 resolve 失败时的执行 reject promise的状态 肯定(fulfilled) 该 Promise 对应的操作成功了 否定( ...

  7. js事件监听器用法实例详解

    这篇文章主要介绍了js事件监听器用法,以实例形式较为详细的分析了javascript事件监听器使用注意事项与相关技巧,需要的朋友可以参考下 本文实例讲述了js事件监听器用法.分享给大家供大家参考.具体 ...

  8. JS Promise的实现原理

    转载自   JS Promise的实现原理 在前端开发过程中,会经常使用到 Promise 模式,可以使异步代码看起来如同步般清新易读,从而从回调地狱中解脱出来.ES6中 已原生支持 Promise, ...

  9. [js] promise的构造函数是同步执行还是异步执行,它的then方法呢?

    [js] promise的构造函数是同步执行还是异步执行,它的then方法呢? promise构造函数是同步执行的,then方法是异步执行的. 个人简介 我是歌谣,欢迎和大家一起交流前后端知识.放弃很 ...

最新文章

  1. Kubelet源码分析(一):启动流程分析
  2. Goldman Sachs 2020校招 Engineer岗
  3. 【以太坊】web3.js的1.0版本和0.2.0版本的安装及区别
  4. tokudb mysql_【MySQL】TokuDB引擎安装教程
  5. Python入门——石头剪刀布程序
  6. python queue get 方法_Python Queue模块详解
  7. TCP协议以及三次握手
  8. 华为拿百亿资金给员工分红,预计每股1.58元
  9. js获取url上的数据;angularjs获取url上的参数
  10. Java PreparedStatement
  11. python进程socket通信_python3 进程间通信之socket.socketpair()
  12. pr如何处理音效,如何让你的声音变得干净又清晰?PR音频降噪教程
  13. 数据质量检查【整理】
  14. java compile方法_Java中带有示例的模式compile()方法
  15. css_径向渐变 radial-gradient()/css generator样式生成器
  16. 分布式ID生成器-订单号的生成(全局唯一id生成策略)
  17. 演唱会门票1秒钟就没了?没错,跟你竞争的不是人……
  18. 学大伟业:2019年生物竞赛学习方法
  19. 如何在PPT中对文字进行错位排版
  20. 点云前视图与俯视图生成

热门文章

  1. 行存储和列存储小介绍
  2. 0欧姆电阻、磁珠及电感的作用
  3. mysql如何恢复单表_MySQL如何恢复单库或单表,以及可能遇到的坑
  4. 【C++ 科学计算】矩阵元素绝对值小于设定值时,元素值变为零
  5. 从工控网络安全攻击中学习的经验
  6. LOESS 局部加权回归介绍
  7. latex做ppt模板
  8. Linux下常用打流方式
  9. php 数字 字母组合,PHP生成数字字母组合或纯数字的唯一订单号
  10. MySQL基础(附练习题+答案)