Promise

在JS的范畴里解决异步加载的方式很多,可以用回调函数,也可以用之前提到的Web Workers来解决.今天来整理另外一种异步处理的方式,Promise.

1.Promise简介

Promise较比回调等异步方式更强大,Promise相当于提供了一个异步事件的容器,事件的结果会一直保留在这个容器里,Promise的用法也跟一般的对象用法类似,利用系统提供的API,来完成各种异步操作.
Promise有几个特点:
1.整个过程是不会被打断的,只要过程开始,就不会被打断,Promise有三个状态,pending(进行中),fulfilled(已完成),rejected(被拒绝),而且状态只会从pending->fulfilled,或者pending->rejected这两种情况,只要状态凝固了确定了,就不会再发生变化,称为resolved(已经定型).
2.状态只要是发生了,就无法去改变这个状态,也就是Promise承诺的含义

2.Promise基本使用

用法实际跟一个常规的对象用法类似,也是需要根据类创建对象,然后使用系统提供的API,完成对应功能的实现

var promise = new Promise(function(resolve, reject){
    // 异步执行的操作代码
        console.log("博观而约取")
    var a = 10;
    // 如果异步执行成功
    if (a < 100) {
        resolve("厚积而薄发");
    } else {
        reject("吾告子止于此矣");
    }
})
// 通过创建的promise对象获取异步操作的值
promise.then(function(val){
    console.log(val);
}, function(error){
    console.log(error)
})
console.log("测试")

上述代码会创建之后就运行,先打印"博观而约取",然后会把对应的异步事件放到Promise中,接下来执行执行最下面的打印,最后处理异步的事件,根据对应的then()的状态调用对应的回调函数,所以最后打印"厚积而薄发",这个过程跟event loop差不多,接下来看一个MDN上提供的异步请求数据的例子

function getJson(url){
        return new Promise((resolve, reject) => {
        var client = new XMLHttpRequest();
        client.open("GET", url);
        client.responseType = "json";
        client.send();
        client.onreadystatechange = function(){
            if (client.readyState !== 4){
                return
            }
            if (client.status == 200){
                resolve(client.response);
            } else {
                reject(new Error(client.statusText))
            }
        }
    })
}
// 方法调用
getJson('getJson.json').then((res) => {
    console.log(res);
})

通过一个函数,然后把Promise对象返回,然后使用then()方法,直接处理对应的结果就可以了.
当第一个异步事件处理完之后,resolve如果在指定另一个promise对象,那第二个会等第一个执行完在处理第二个,相当于第二个也在event loop里,在loop里等待事件的处理

3.Promise的属性和方法

Promise属性有两个,一个是length,这个属性值始终为1,它代表构造函数参数的数量,另外一个是prototype,构造函数的原型,
原型上提供了一个属性, constructor的作用是返回创建promise对象的函数.两个方法是非常常用的:
一是then(),上面的例子也使用过,它的作用是把fulfilled和rejected两种状态对应的回调函数传到promise对象中,第一个参数是fulfilled状态的,第二个参数是可选的,对应rejected状态的回调函数.这个方法会返回promise对象,所以可以使用哪种链式写法.参考如下

getJson('getJson.json').then((res) => {
        console.log(res);
}).then(() => {
    console.log("aaa");
},() => {
    console.log("bbb");
})

当第一个过程结束之后,执行完then的回调函数,会自动返回一个新的promise,这个新的实例跟之前网络请求所创建的不是同一个,我第一次看的时候以为还会调用继续请求数据,实际已经跟第一个promise没有关系了,开始进入一个新的周期,根据新的周期的状态去选择是resolve还是reject,在RN的网络请求中,基本上都是这种重叠的链式写法
二是catch(),这个方法相当于then(null, reject),相当于在调用then的时候,如果发生了异常,会直接调用catch()方法,去捕获这个异常.如果在resolve状态里发生了异常,也会被catch捕捉到

var promise = new Promise(function(resolve, reject) {
        // resolve("挺好");
    throw new Error("测试");
})
promise.then((res) => {
        console.log(res);
}).catch((err) => {
    console.log(err);
})

但是如果把注释打开,先执行resolve,也就是先改变了promise对象的状态的话,即使写了throw也不会触发,因为那会状态已经从pending变成fulfilled,跟catch无关了,而且状态不会再发生变化了,用法跟try/catch很接近.
在RN中,关于then的写法上,都只写一个resolve的回调函数,然后在结尾处写一个catch,这样写在写法上也跟try/catch一致.而且在链式写法上,如果其中有一个环节发生了异常,这个异常会一直传递,直到有一个catch把这个异常捕获到,所以在RN里会在最后一步写一个catch来收尾,找了一个RN的网络请求

fetch(url).then((response) =>response.json())
.then((responseData)=>{
        // 数据处理
}) .catch((error)=>{
       // 异常处理
})

简单的汇总和整理了一下Promise的用法,实际上用的地方很多,axios,RN都采用这种ES6的新规范,最后一句:人似秋鸿来有信,事如春梦了无痕

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,509评论 6 504
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,806评论 3 394
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,875评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,441评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,488评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,365评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,190评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,062评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,500评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,706评论 3 335
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,834评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,559评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,167评论 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,779评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,912评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,958评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,779评论 2 354

推荐阅读更多精彩内容

  • 00、前言Promise 是异步编程的一种解决方案,比传统的解决方案——回调函数和事件——更合理和更强大。它由社区...
    夜幕小草阅读 2,133评论 0 12
  • Promiese 简单说就是一个容器,里面保存着某个未来才会结束的事件(通常是一个异步操作)的结果,语法上说,Pr...
    雨飞飞雨阅读 3,358评论 0 19
  • 本文适用的读者 本文写给有一定Promise使用经验的人,如果你还没有使用过Promise,这篇文章可能不适合你,...
    HZ充电大喵阅读 7,307评论 6 19
  • Promise的含义:   Promise是异步编程的一种解决方案,比传统的解决方案——回调函数和事件——更合理和...
    呼呼哥阅读 2,170评论 0 16
  • 秦朝中国历史上第一个大一统王朝,但是为什么他统一的时间那么短,仅仅只有15年。 首先肯定是因为秦始皇的暴政,秦...
    老珂珂阅读 732评论 0 0