今天我们来说then一些特殊情况以及Promise.all()与Promise.race()。

我们都知道函式作为参数传入时,可以参照的方式传入,也能传入时执行拿回传值作使用:

function useReference(cb){

console.log(“useReference”);

console.log(cb());

}

function useFunctionValue(val){

console.log(val);

}

function funB(){

return“funB”;

}

useReference(funB);

useFunctionValue(funB());

但是在Promise中使用then时,要注意到:

onFulfilled或onRejected不是函式时,忽略跳过(thenorwegianstig)。

function doA(){

console.log('doA start')

return new Promise(function(resolve,reject){

console.log('doA end');

resolve(1);

})

}

function doB(){

console.log('doB');

return 10;

}

function final(value){

console.log('final');

console.log(value);

return 0;

}

//正常函式参照写法

doA().then(doB).then(final);

//doA start

//doA end

//doB

//final

//10

上面这个是一般我们把函式当参数传入时的做法,那如果在传入doB时就先执行了,会发生什么事情呢?

doA().then(doB()).then(final);

//doA start

//doA end

//doB

//final

//1

在执行then(doB())时,虽然有说到如果不是函式便会跳过,但我们知道函式的回传值也可以为函式,所以JS还是会执行它,当然最后得到的只是doB()的回传值2。

所以then(doB())会继续用fulfilled的状态,带着值1回传新的Promise物件给下个then方法。

如果真的要这样写,可以改写成这样:

doA()

.then((val)=>{

})

.then(final);

Promise.all()

前面在用Promise时都是一次进行一个任务,但如果今天需要一次执行多个任务时,像是同时发出两个ajax请求,就需要用Promise.all()。

语法如下:

Promise.all(iterable);

iterable代表可以传入一个数组或字串,一般来说都会使用数组当作参数。

Promise.all()会将数组中的值全部执行完后,才会接着执行下个then方法。这边要注意到几个规则:

数组索引值与执行顺序无关。

数组中的值如果不是Promise物件,则会自动使用Promise.resolve方法转换。

执行过程中只要数组其中一个值发生错误,会立即回传reject状态。

执行完成后会回传一个数组值。

最好每次在使用时加上错误处理。当然一般Promise也要!

让我们来看几个例子吧:

var promise1 = 42;

var promise2 = Promise.resolve(“hihi”);

var promise3 = new Promise((resolve,reject)=> {

setTimeout(()=> resolve('Im async'),1000)

});

Promise.all([promise1,promise2,promise3]).then((value)=> {

console.log(value)

}).catch((err)=> {

console.log(err.message)

});

//[42,“hihi”,“Im async”]

Promise.race()

Promise.race()的规则跟Promise.all()一样,区别在于只会回传最快完成的那个,不论最快成功或失败。

通常用于获取资源时有很多个地方,像是服务器端与自己电脑端,只需要取最快回来的就好。

var promise1 = new Promise((resolve,reject)=> {

setTimeout(()=> resolve('delay 200'),200)

});

var promise2 = new Promise((resolve,reject)=> {

setTimeout(()=> resolve('delay 1000'),1000)

});

var promise3 = new Promise((resolve,reject)=> {

setTimeout(()=> resolve('delay 2000'),2000)

});

Promise.race([promise1,promise2,promise3]).then((value)=> {

console.log(value)

}).catch((err)=> {

console.log(err.message)

});

//delay 200

到这边Promise就告一段落了,希望大家看完后有比较了解。

如果有错误及来源未附上也欢迎留言指正,那么我们明天见(aichi-kaigo)。

学JS的心路历程-Promise(三)的更多相关文章

  1. 学JS的心路历程-Promise(二)

    昨天有说到Promise的创建以及then的用法,今天我们来看错误处理. then onRejected 我们昨天有提到说,then两个函式参数,onFulfilled和onRejected,而onR ...

  2. 学JS的心路历程-Promise(一)

    今天在进入Promise代码之前,我们先来用个例子来解释Promise是什么. 未来值 假设我们今天来到快餐店,点了一个汉堡,付钱给店员. 点了餐点并付费,可以理解为我们发送了一个请求,希望得到一个回 ...

  3. 学JS的心路历程 -函式(三)this

    this是什么,取决于被呼叫的呼叫地点. 昨天有提到说,呼叫函式时候会传递隐含参数:arguments和this并讲解了arguments,今天我们就来探讨this吧! 什么是this 我们都会呼叫函 ...

  4. 学JS的心路历程-物件与原型(三)

    昨天有说明到函式与建构式的原型,及指定建构式函式原型为另一个建构式函式,但其实这会造成复写constructor的问题. 复写constructor的问题(vmwork) 我们昨天有提到「建构式函式可 ...

  5. 学JS的心路历程 - PixiJS -基础(三)

    今天我们来试着移动图片吧! 首先,一样先把图片放到PIXI的stage中: let app = new PIXI.Application({ width: 800, height: 600, back ...

  6. 学JS的心路历程Day26 - PixiJS -入坑

    后来知道也可以透过canvas让网页动起来! 而PixiJS是使用WebGL在canvas上绘制内容与制作动态 且同时有下列特色: 支持多点触控 掩码与混合模式 可外加WebGL滤镜 多装置支持 等等 ...

  7. 学JS的心路历程-物件与原型(一)

    前两天说明面向对象的三大特性及JS不符合面向对象,只能称作支持面向对象而已,今天我们来看看JS的原型继承. 首先我们先来看,什么是原型(vmwork): 两个物件之间的原型关系(prototype r ...

  8. 学JS的心路历程-JS支持面向对象?(一)

    昨天在看Prototype看到JS支持面向对象,被前辈问到说那什么是面向对象?JS是面向对象语言吗? 便开始了一连串艰辛爬文过程,今天就来看一下两者有什么差异吧(rgwyjc)! 首先面向对象有三大特 ...

  9. 学JS的心路历程-闭包closure

    闭包是是纯函式语言的一个特性,也是JS的一个关键性的特色,虽然不了解也能开发程序,但我们不是这种人对吧? 闭包不仅可以减少某些高阶功能的代码数量和复杂度,并且可以让我们做到原本无法做的复杂功能.听到这 ...

随机推荐

  1. CS229 6.3 Neurons Networks Gradient Checking

    BP算法很难调试,一般情况下会隐隐存在一些小问题,比如(off-by-one error),即只有部分层的权重得到训练,或者忘记计算bais unit,这虽然会得到一个正确的结果,但效果差于准确BP得 ...

  2. solr 使用edismax来控制评分

    如何控制评分 如果设置了sort字段,那么将会按照sort字段的顺序返回结果. 如果没有设置sort字段,那么将会根据相关度打分来排序.也就是说,相关度更高的排在前面. 如何来定制适合自身业务的排序打 ...

  3. Python NLTK——代码重用,F5运行py文件cmd闪退,invalid syntax

    打开IDLE,对代码进行保存(Ctrl+S)后,代码都是可以运行的. 但是打开文件就会弹出cmd并闪退,截了好几次图发现报的是Invalid syntax的错. 后来发现应该在IDLE中新建一个fil ...

  4. sshd_config

    1.sshd_config 选项不区分大小写,参数区分大小写. sshd_config选项及参数 选项 默认值 说明 AcceptEnv 不接受任何值   AddressFamily any any/ ...

  5. IIS w3wp对应的应用程序

    IIS7以前我們用IISApp查看IIS哪些服務已啟動,但在IIS7已經不適用了,新語法是appcmd.exe list wp.你可以在%windir%\system32\inetsrv\底下找到ap ...

  6. linux path 与 classpath 区别

    一.OS依据path中的路径信息来寻找可执行指令: 例如: cat /etc/profile 我们就可以在任意目录执行hadoop / hdfs / yarn / java 等相关命令了 export ...

  7. 16. js方法传多个参数的实例

    field : 'operate',width : fixWidth(1/6),title : '操作',align : 'center',formatter : function(id,rowDat ...

  8. exe加载DLL的时候会有一系列的搜索路径

    假如安全DLL搜索模式启用,搜索顺序如下: 1. 应用程序所在的路径 2. Windows SYSTEM目录.通过调用GetSystemDirectory函数可以获取这个目录的路径. 3. 16位系统 ...

  9. 对象 Object

    在js 中创建最简单的对象,然后给它添加属性或者方法 示例如下: var obj = new Object(); //或者 var obj = {}; obj.name = '张三'; obj.fun ...

  10. JAVA版开源微信管家—JeeWx捷微3.2版本发布,支持微信公众号,微信企业号,支付窗、小程序

    JeeWx捷微3.2微信企业号升级版本发布^_^ JeeWx捷微V3.2——多触点管理平台(支持微信公众号,微信企业号,支付窗.小程序)   JeeWx捷微V3.2.0版本引入了更多新特性,支持微信公 ...