Promise的实现原理
1.Promise 介绍
Promise类似一个事务管理器,将用户异步操作流程用流水的形式来表达,用来延迟deferred和异步asynchronous. 特点如下:
(1)对象的状态不受外界影响
Promise对象有三种状态
Pending 进行中
Resolved 完成状态
Rejected 失败状态
只有异步操作的结果,可以决定当前是哪种状态,任何其他操作都无法改变这种状态
(2)一旦状态改变,就不会再变,任何时候都可以得到这个结果
状态改变: Pending—> Resolved / Pending —> Rejected
事件的执行一旦错误,再去监听是得不到结果的。
(3)Promise 对象有两个重要方法,一个是then, 另一个是resolve
then: 将事务流添加到事务队列中
resolve:开启流程,让真个流程从第一个事务开始执行
(4)Promise的常用方式如下:
var p = new Promise(function(resolve, reject){ … //处理事务 resolve() …. }); p.then(function(value){ //处理成功 }, function(reason){ //失败处理 }).always(function(){ //总是会执行
});
当前Promise是ES6的一个重要特性,JQuery1.8以后也实现了Promise对象.
2.ES6的Promise
function helloWorld(flag){
return new Promise(function(resolve,reject){
if(flag){
resolve("Hello World!")
}else{
reject("Error")
}
});
} //helloWord方法返回一个new的Promise对象,Promise回调有两个参数分别处理成功和失败,不想处理的直接传入null即可 helloWorld(true).then(function(message){},function(error){});
helloWorld(true).then(function(message){}); //不处理失败
每一个then 执行后,又返回一个Promise对象
Promise.all 可以接收一个元素为 Promise 对象的数组作为参数,当这个数组里面所有的 Promise 对象都变为 resolve 时,该方法才会返回。结果为Promise对象结果集合。
Promise.all([promise1, promise2]).then(function (result) { console.log(result); // [“promise1Result”, “promise2result”] });
不管promise1执行快还是promise2执行快,promise.all会按照数组的吮吸返回结果。
日常开发中经常会遇到这样的需求,在不同的接口请求数据然后拼合成自己所需的数据,通常这些接口之间没有关联(例如不需要前一个接口的数据作为后一个接口的参数),
这个时候 Promise.all 方法就可以派上用场了。
3.JQuery中的Promise实现:
在jquery1.5之前传统的写法是
$.ajax({ url:’/ServerResource.txt’, success: handlerSuccess function, error: handlerError function }); //$.ajax返回一个XHR(XMLHttpRequest)对象,不能进行链式操作
在jquery1.5之后,$.ajax 会返回$.Deferred对象,新的写法:
var promise = $.ajax({
url: "/ServerResource.txt"
});
promise.done(handlerSuccess);
promise.fail(handlerError);
promise.always(alwaysFunction);
$.ajax() 会返回一个$.Deferred对象,执行完done, fail, always会返回一个新的$.Deferred对象,可以进行链式操作
promise.done(handlerSuccess).fail(handlerError).always(alwaysFunction)
$.Deferred对象的好处就是可以任意添加回调函数,就是可以出现多个.done()处理
promise.done(handlerSuccess1).done(handlerSuccess2).fail(handlerError).always(alwaysFunction)
另外一种产生链式调用的方式是利用Promise的 then 方法,它接受三个event handlers作为参数,
在jquery 1.8之前,对于多个回调函数,有需要以数组方式传入三个参数:
$.ajax({url: "/ServerResource.txt"})
.then([successFunction1, successFunction2, successFunction3],
[errorFunction1, errorFunction2]);
//same as
var jqxhr = $.ajax({
url: "/ServerResource.txt"
});
jqxhr.done(successFunction1);
jqxhr.done(successFunction2);
jqxhr.done(successFunction3);
jqxhr.fail(errorFunction1);
jqxhr.fail(errorFunction2);
1.8版本之后,then会返回一个新的Promise,它可以通过一个函数过滤掉Deferred对象的状态和值,用于取代不被推荐使用的 defeered.pipe() 方法。
$.ajax() 返回Promise对象,处理方式和ES6一致。
var promise = $.ajax({
url: "/ServerResource.txt"
});
promise.then(successFunction, errorFunction);
//如果不想处理某个事件类型,可以传入Null
var promise = $.ajax({
url: "/ServerResource.txt"
});
promise.then(successFunction); //no handler for the fail() event
then()方法还能逐次调用多个方法,可以用于处理有着先后顺序或者依赖的多个Ajax请求: var promise = $.ajax("/myServerScript1");
function getStuff() {
return $.ajax("/myServerScript2");
}
promise.then(getStuff).then(function(myServerScript2Data){ //第一个AJAX的response 作为第二个AJAX的入参
// Do something
});
Promise的实现原理的更多相关文章
- Promise内部实现原理
promise内部实现原理: function $Promise(fn) { // Promise 的三种状态 this.PENDING = 'pending' this.RESOLVED = 're ...
- 160701、理解 Promise 的工作原理
Javascript 采用回调函数(callback)来处理异步编程.从同步编程到异步回调编程有一个适应的过程,但是如果出现多层回调嵌套,也就是我们常说的厄运的回调金字塔(Pyramid of Doo ...
- 160623、理解 Promise 的工作原理
Javascript 采用回调函数(callback)来处理异步编程.从同步编程到异步回调编程有一个适应的过程,但是如果出现多层回调嵌套,也就是我们常说的厄运的回调金字塔(Pyramid of Doo ...
- Promise.race 的原理
// race的原理 Promise.race = function(values){ return new Promise((resolve,reject)=>{ for(let i = 0 ...
- Promise.all 的原理
// all的原理 Promise.all = function(values){ return new Promise((resolve,reject)=>{ let results = [] ...
- JavaScript中Promise 使用、原理以及实现过程
1.什么是 Promise promise 是目前 JS 异步编程的主流解决方案,遵循 Promises/A+ 方案. 2.Promise 原理简析 (1)promise 本身相当于一个状态机,拥有三 ...
- promisify,promisifyAll,promise.all实现原理
1.promisify function toPrimisify (fn){ return function (...args){ return new Promise(function(r ...
- Promise原理—一步一步实现一个Promise
promise特点 一个promise的当前状态只能是pending.fulfilled和rejected三种之一.状态改变只能是pending到fulfilled或者pending到rejected ...
- promise原理
简介 Promise 对象用于延迟(deferred) 计算和异步(asynchronous )计算.一个Promise对象代表着一个还未完成,但预期将来会完成的操作.Promise 对象是一个返 ...
随机推荐
- STL 小白学习(1) 初步认识
#include <iostream> using namespace std; #include <vector> //动态数组 #include <algorithm ...
- python 在.py文件中调用其他.py内的函数
假设名为A.py的文件需要调用B.py文件内的C(x,y)函数 假如在同一目录下,则只需 import B if __name__ == "__main__": B.C(x,y ...
- select 取value值
<md-select ng-model="alarmSelect" style="margin: 0px 0px 0px 0px;" ng-change= ...
- ADO.NET之SqlConnection、sqlcommand的应用(学习笔记)
一.知识描述点 1.SqlConnection (1)使用SqlConnection类可以连接到SQL Server数据库.SqlConnection对象的主要属性和方法如下: ——属性:Connec ...
- 使用Java API方式连接HDFS Client测试
IDEA中新建Maven工程,添加POM依赖, 在IDE的提示中, 点击 Import Changes 等待自动下载完成相关的依赖包. <?xml version="1.0" ...
- 马凯军201771010116《面向对象程序设计(java)》第七周学习总结
理论与知识部分 多态性:概念:指在程序中同一符号在不同的情况下具有不同的解释.超类中定义的域或方法,被子类继承之后,可以具有不同的数据类型或表现出不同的行为.这使得同一域或方法在超类及各个子类中具有不 ...
- 3.5 unittest生成测试报告HTMLTestRunner
3.5 unittest生成测试报告HTMLTestRunner 前言批量执行完用例后,生成的测试报告是文本形式的,不够直观,为了更好的展示测试报告,最好是生成HTML格式的.unittest里面是不 ...
- centos7 ssh连接慢
指的是连接到centos7,输入密码后要等很久才会返回.之前很多人遇到的问题都是由于/etc/ssh/sshd_config的UseDNS配置项和GSSAPIAuthentication配置项引起的, ...
- 多设备同时进行monkey抗压测试
adb工具操作monkey抗压测试. 首先得安装adb工具,且配置好环境配置.推荐链接: 安装方法:https://blog.csdn.net/L_201607/article/details/781 ...
- PHP常见错误级别及错误码
数字 常量 说明 1 E_ERROR 致命错误,脚本执行中断,就是脚本中有不可识别的东西出现 举例: Error:Invalid parameters. Invalid parameter name ...