学JS的心路历程-Promise(三)
今天我们来说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(三)的更多相关文章
- 学JS的心路历程-Promise(二)
昨天有说到Promise的创建以及then的用法,今天我们来看错误处理. then onRejected 我们昨天有提到说,then两个函式参数,onFulfilled和onRejected,而onR ...
- 学JS的心路历程-Promise(一)
今天在进入Promise代码之前,我们先来用个例子来解释Promise是什么. 未来值 假设我们今天来到快餐店,点了一个汉堡,付钱给店员. 点了餐点并付费,可以理解为我们发送了一个请求,希望得到一个回 ...
- 学JS的心路历程 -函式(三)this
this是什么,取决于被呼叫的呼叫地点. 昨天有提到说,呼叫函式时候会传递隐含参数:arguments和this并讲解了arguments,今天我们就来探讨this吧! 什么是this 我们都会呼叫函 ...
- 学JS的心路历程-物件与原型(三)
昨天有说明到函式与建构式的原型,及指定建构式函式原型为另一个建构式函式,但其实这会造成复写constructor的问题. 复写constructor的问题(vmwork) 我们昨天有提到「建构式函式可 ...
- 学JS的心路历程 - PixiJS -基础(三)
今天我们来试着移动图片吧! 首先,一样先把图片放到PIXI的stage中: let app = new PIXI.Application({ width: 800, height: 600, back ...
- 学JS的心路历程Day26 - PixiJS -入坑
后来知道也可以透过canvas让网页动起来! 而PixiJS是使用WebGL在canvas上绘制内容与制作动态 且同时有下列特色: 支持多点触控 掩码与混合模式 可外加WebGL滤镜 多装置支持 等等 ...
- 学JS的心路历程-物件与原型(一)
前两天说明面向对象的三大特性及JS不符合面向对象,只能称作支持面向对象而已,今天我们来看看JS的原型继承. 首先我们先来看,什么是原型(vmwork): 两个物件之间的原型关系(prototype r ...
- 学JS的心路历程-JS支持面向对象?(一)
昨天在看Prototype看到JS支持面向对象,被前辈问到说那什么是面向对象?JS是面向对象语言吗? 便开始了一连串艰辛爬文过程,今天就来看一下两者有什么差异吧(rgwyjc)! 首先面向对象有三大特 ...
- 学JS的心路历程-闭包closure
闭包是是纯函式语言的一个特性,也是JS的一个关键性的特色,虽然不了解也能开发程序,但我们不是这种人对吧? 闭包不仅可以减少某些高阶功能的代码数量和复杂度,并且可以让我们做到原本无法做的复杂功能.听到这 ...
随机推荐
- Hive数据据类型 DDL DML
Hive的基本数据类型 DDL DML: 基本数据类型 对于Hive而言String类型相当于数据库的varchar类型,该类型是一个可变的字符串,不过它不能声明其中最多能存储多少个字符,理论上它可以 ...
- kafka 消息系统
一.为什么需要消息系统 1.解耦: 允许你独立的扩展或修改两边的处理过程,只要确保它们遵守同样的接口约束. 2.冗余: 消息队列把数据进行持久化直到它们已经被完全处理,通过这一方式规避了数据丢失风险. ...
- 检查Linux系统cpu--内存---磁盘的脚本
花了一天写了三条命令分别检查cpu,内存,磁盘 [root@localhost ~]# cat cpu_mem_disk.sh #!/bin/sh # echo "1 检查cpu利用率--- ...
- 5.1_非监督学习之sckit-learn
非监督学习之k-means K-means通常被称为劳埃德算法,这在数据聚类中是最经典的,也是相对容易理解的模型.算法执行的过程分为4个阶段. 1.首先,随机设K个特征空间内的点作为初始的聚类中心. ...
- 1.1使用java数组,并开始封装我们自己的数组
今天感冒了,全身酸软无力,啥样不想做,就来学习吧,此节我们从初步使用java中提供的数组,然后分析相关情况,过渡到封装我们自己的数组. 一.我们先来感受一下java提供的数组,以整型数组(int[]) ...
- github中SSH公钥的生成与添加
在终端中输入ssh-keygen -t rsa -C "133XXXXXX@qq.com" 按3个回车,密码为空这里一般不使用密钥. 最后得到了两个文件:id_rsa和id_rsa ...
- centos7扩展根分区
参考网站:http://www.360doc.com/content/18/0128/11/52410512_725728162.shtml VirtualBox中安装了CentOS 7,给同事用来做 ...
- 8. Object转Map,Map转Object
法一:使用reflect进行转换 public static Object mapToObject(Map<String, Object> map, Class<?> bean ...
- java reflect反射调用方法invoke
类定义 package Reflect; public class MyTest { public int a; public static int b; public static final in ...
- QT中控制台程序运行问题
环境: ubuntu14.04 问题与解决方法: QT中的控制他程序,默认运行方式是直接输出到Output窗口中来.我的程序需要从控制台输入,这时候默认的运行方式就不行了.通过设置工程全选项让它在终端 ...