异步编程之Javascript Promises 规范介绍

Promises是一种关于异步编程的规范,目的是将异步处理对象和处理规则进行规范化,为异步编程提供统一接口。本文简要的介绍了Promises的基础知识,希望我回调函数js们我们javascript百炼成仙免费阅读能够更好的使用Promises,更轻松的编写代码。

什么是 Promises

PromisesPromises是一种关于异步编程的规范,目的是将异步处理对象和处理规则进行规范化,为异步编程提供统一接口。

传统回调函数

说到JavaScript的云计算导论异步编程处理,通常我们会想到回调函数,如下面的代码:

getFileAsync("1.txt", function(error, result){

if(error){

throw error;

}

// 取得成功时的处理

});

上面的代码定义了一个获取文件内容的异步编程和同步编程的区别函数,读取完成后回调用传入的回promise是及物动词吗调函数,对于下面的场景:

读取文件 1.txt 的内容,其内容也是一个文件地址,我们称为 2.txt

读取文件 2.txt 的内容,其内容还是一个文件地址,我们称为 3.txt云计算最简单解释

- 读取文件 3.txt 的内容

使用回调函数的代码如下:

getFileAsync(“1.txt", function(error1, result1){

if(error1){

throw error1;

}

getFileAsync(result1, function(error2, result2){

if(error1){

throw error1;

}

getFileAsync(result2, function(error3, result3){

console.log(result3);

});

});

});

这就是所谓的回调金字塔,回调函数嵌套很深,代码很不好看,也不容易阅读。而Promise正是碾平异步回调的解决方案。

Promises 规范

Prom云计算是什么ises/A(​​http://wiki.commonjs.org/wiki/Promises/A​云计算​)是由CommonJS组织制定的异步模式编程规范,提供了一个在程序中描述延时(或将来)概念的解决方案。主要的思想是执行openstack安装部署centos7一个异步方法的时候,不阻塞应用程序,返回一个Promise对象

Promises/A+(​​https://promisesaplus.com/​​)规范是对Prom回调函数是什么意思ises/A规范javascript什么意思的补充和修改。

Promise对象有三种状态:初始状态(pending)、成功(fulfilled)和失败(rejected),其中pend回调函数是什么ing为初始状态,fulfilled和rejected为结束状态。状态转换关系为:pending-&promise思维导图gt;fulfilled,pending->rejected,pr云计算与物联网的关系omise对象从Pending转换为FulfilledRejected之后, 这个promise对象的状态就不会再发生任何变化,如下图:

Promise是一个拥有 then 方法的对象,then接口用于监听一个Promise的不同状态。

then(fulfilledHandler, errorHandler, progressHandler);

添加fulfilledHandler、errorHandle云计算分为哪些类型r和progressHandler后,promise对象就构成了。fulfilledHPromisesandler是在promise被装载数据的时候调用,errorHandler在promise失败的时候调用,progressHandler则在progress事件触发的时候openstack发布的自己的第13个版本是调用。

var promise = getAsyncPromise("fileA.txt");

promise.then(function(result){

// 获取文件内容成功时的处理

}, function(error){

// 获取文件内容失败时的处理

});


Pr云计算分为哪些类型omises
链式调用

then方法在fulfilledHandler或者errorHandler回调完成之后,会返回一个新的promise对象,而不是原来的Promise对象,这样一来,promise操作promise思维导图就可promise三种状态以形成链式调用。

var promise = new Promise(function (resolve) {

resolve(100);

});



promise.then(function(value) {

return value *2;

}).then(function(value) {

return value *2;

}).then(function(value) {

console.log(value); // => 100 * 2 * 2

});

Promises 错误处理javascript是干什么的

then()函数接收两个回调函数作为参数。第二个回调函数在Promise变为rejected时被触发的函数。PPromisesromise还提供了一个catch()函数来处理Promise的rejected状态。看下面的代码:

promise.then(fucntion(result){

console.log('Got data!',relust);

}).catch(function(error){

console.log('Error occurred!',error);

});

上面的代码其实等价于:

promise.then(function(result){

console.log('Got data',result);

},function(error){

console.log('Error occurred!',error);

});


浏览器支持回调函数的作用

Promises 现在已经是云计算JavaScript标准的一部分了, 几乎全部的浏览器已经实现了Prompromise三种状态ises API,浏览器兼容性如下:promises

异步编程之Javascript Promises 规范介绍

本文简要的介绍了Promises的基础知识,希望我们我们能够更好的使用Prjavascript:void(0)omises,更轻松的编写代码。