Promise对象
1.Promise思想:每一个异步任务立刻返回一个Promise对象,由于是立刻返回,所以可以采用同步操作的流程。这个Promises对象有一个then方法,允许指定回调函数,在异步任务完成后调用。
// 传统写法
step1(function (value1) {
step2(value1, function(value2) {
step3(value2, function(value3) {
step4(value3, function(value4) {
// ...
});
});
});
}); // Promises的写法
(new Promise(step1))
.then(step2)
.then(step3)
.then(step4);
传统的回调函数写法使得代码混成一团,变得横向发展而不是向下发展。Promises规范就是为了解决这个问题而提出的,目标是使用正常的程序流程(同步),来处理异步操作。它先返回一个Promise对象,后面的操作以同步的方式,寄存在这个对象上面。等到异步操作有了结果,再执行前期寄放在它上面的其他操作。
ECMAScript 6将其写入语言标准,因此目前JavaScript语言原生支持Promise对象。
2.Promise接口
接口状态
(1)未完成 pending
(2)完成 resolved或者fulfilled
(3)失败 rejected
状态变化途径
(1)未完成-完成
(2)未完成-失败
Promise对象最终结果
(1)异步操作成功,Promise对象传回一个值,状态变为resolved
(2)异步操作失败,Promise对象抛出错误,状态变为rejected
then方法
Promise对象使用then方法添加回调函数,then方法可以接受两个回调函数,一个是异步操作成功(状态为resolved)时的回调函数,一个是异步操作失败(状态为rejected)时的回调函数。
then方法可以链式调用:
po
.then(step1)
.then(step2)
.then(step3)
.then(
console.log,
console.error
);
上面代码中,po的状态一旦变为resolved,就依次调用后面每一个then指定的回调函数,每一步都必须等到前一步完成,才会执行。最后一个then方法的回调函数console.log和console.error,用法上有一点重要的区别。console.log只显示回调函数step3的返回值,而console.error可以显示step1、step2、step3之中任意一个发生的错误。也就是说,假定step1操作失败,抛出一个错误,这时step2和step3都不会再执行了(因为它们是操作成功的回调函数,而不是操作失败的回调函数)。Promises对象开始寻找,接下来第一个操作失败时的回调函数,在上面代码中是console.error。这就是说,Promises对象的错误有传递性。
3.Promise对象的生成
ES6提供了原生的Promise构造函数,用来生成Promise实例。
 var promise = new Promise(function(resolve, reject){
     //异步操作的代码
     if(/*异步操作成功*/){
         resolve(value);
     }else{
         reject(error);
     }
 })        
resolve函数的作用是,将Promise对象的状态从“未完成”变为“成功”(即从Pending变为Resolved),在异步操作成功时调用,并将异步操作的结果,作为参数传递出去;reject函数的作用是,将Promise对象的状态从“未完成”变为“失败”(即从Pending变为Rejected),在异步操作失败时调用,并将异步操作报出的错误,作为参数传递出去。
4.Promise用法辨析
(1)finalHandler回调函数的参数是doSomethingElse函数的运行结果
 doSomething().then(function () {
   return doSomethingElse();
 }).then(finalHandler);
(2)finalHandler回调函数的参数是undefined
 doSomething().then(function () {
   doSomethingElse();
   return;
 }).then(finalHandler);
(3)finalHandler回调函数的参数,是doSomethingElse函数返回的回调函数的运行结果
doSomething().then(doSomethingElse())
.then(finalHandler);
(4)doSomethingElse会接收到doSomething()返回的结果
doSomething().then(doSomethingElse)
.then(finalHandler);
5.Promise优缺点
优点:让回调函数变成了规范的链式写法,程序流程可以看得很清楚。如果一个任务已经完成,再添加回调函数,该回调函数会立即执行。所以,你不用担心是否错过了某个事件或信号。
缺点:编写和理解都相对比较难。
如有错误,请您指正!
参考文档:
Promise对象的更多相关文章
- angular学习笔记(二十八-附2)-$http,$resource中的promise对象
		
下面这种promise的用法,我从第一篇$http笔记到$resource笔记中,一直都有用到: HttpREST.factory('cardResource',function($resource) ...
 - ES6深入学习记录(二)promise对象相关
		
1.Promise的含义 Promise是异步编程的一种解决方案,比传统的解决方案--回调函数和事件更合理和强大.ES6将其写进了语言标准,统一了用法,原生提供了promise对象. 所谓Promis ...
 - es6中的promise对象
		
Promise是异步里面的一种解决方案,解决了回调嵌套的问题,es6将其进行了语言标准,同意了用法,提供了`promise`对象, promise对象有三种状态:pending(进行中) .Resol ...
 - ES6的promise对象应该这样用
		
ES6修补了一位Js修真者诸多的遗憾. 曾几何时,我这个小白从js非阻塞特性的坑中爬出来,当我经历了一些回调丑陋的写法和优化的尝试之后,我深深觉得js对于多线程阻塞式的开发语言而言,可能有着其太明显的 ...
 - Angularjs promise对象解析
		
1.先来看一段Demo,看完这个demo你可以思考下如果使用$.ajax如何处理同样的逻辑,使用ng的promise有何优势? var ngApp=angular.module('ngApp',[]) ...
 - JavaScript异步编程(1)- ECMAScript 6的Promise对象
		
JavaScript的Callback机制深入人心.而ECMAScript的世界同样充斥的各种异步操作(异步IO.setTimeout等).异步和Callback的搭载很容易就衍生"回调金字 ...
 - angularJS中的Promise对象($q)的深入理解
		
原文链接:a better way to learn AngularJS - promises AngularJS通过内置的$q服务提供Promise编程模式.通过将异步函数注册到promise对象, ...
 - 通过一道笔试题浅谈javascript中的promise对象
		
因为前几天做了一个promise对象捕获错误的面试题目,所以这几天又重温了一下promise对象.现在借这道题来分享下一些很基础的知识点. 下面是一个面试题目,三个promise对象捕获错误的例子,返 ...
 - ECMAScript6的Promise对象
		
1. 概念 Promise对象用于异步(asynchronouss)计算,一个Promise对象代表着一个还未完成,但预期完成的操作. 2. 出现原因: 1) 如果你需要通过ajax发送多次请求,而 ...
 
随机推荐
- 【Html 学习笔记】第二节——文本格式
			
上一节基本已经了解了一些html的基础,这一节主要学习html处理文本相关内容,直接看内容吧. 字体: 预格式文本:<pre> 地址:<address> 缩写:<abbr ...
 - spark-submit 分发应用
			
Spark 提供了一个名为spark-submit 的单一工具来跨集群管理器的提交作业,命令如下: bin/spark-submit [options] <app jar | python fi ...
 - QtAlgorithms
			
qSort() qCopy() qFill() #include <QCoreApplication> #include<QDebug> #include<QVector ...
 - java中一个查询业务的流程
			
因为有用到分页,首先建一个page类 1 public class Page<T> { 2 private int pageSize; //每页显示条数 3 private int cur ...
 - GIT 配置管理
			
git版本控制开发流程小结笔记(一) 收藏 何良瑞Nyanko君 ...
 - Android JavaMail
			
一.简介 JavaMail API提供了一种与平台无关和协议独立的框架来构建邮件和消息应用程序. JavaMail API提供了一组抽象类定义构成一个邮件系统的对象.它是阅读,撰写和发送电子信息的可选 ...
 - Ubuntu server12.04安装JDK+Tomcat+mysql
			
一.安装JDK 1.首先到官网上下载jdk-7u79-linux-x64.tar.gz. 2.将jdk-7u79-linux-x64.tar.gz拷贝到/usr/lib/jdk/目录下面,这里如果没有 ...
 - SpringMVC常用配置-Controller中的各种配置(基于Java API和注解)
 - Linuxb笔记
			
3.登录mysql 开启MySQL服务后,使用MySQL命令可以登录.一般使用mysql -uroot -p即可.如果数据库不是本机,则需要加参数,常用参数如下:1,-h,指定ip地址,默认为loca ...
 - margin属性
			
可以设置position:absolute/relative/fixed,通过调节top/bottom/left/right实现元素的定位,这样很好,但是有时候想通过margin来实现. 下面是mar ...