学JS的心路历程-Promise(二)
昨天有说到Promise的创建以及then的用法,今天我们来看错误处理。
then onRejected
我们昨天有提到说,then两个函式参数,onFulfilled和onRejected,而onRejected则是Promise物件状态转为rejected时呼叫。
不过在使用时要注意Promise是使用split-callback(分离回呼)风格,所以如果我们这样写:
var promise = new Promise((resolve,reject)=> {
resolve(4)
})
promise
.then((val)=>{
throw Error(“error!!“);
})
.then(null,(error)=>{
console.log('err1',error.message);
return“I'm reject return”
});
是没有办法顺利接到错误的,会直接跳出浏览器的错误警告(qstxsj),
但这不是我们所希望的,所以我们必须这样写:
var promise = new Promise((resolve,reject)=> {
resolve(4)
})
promise
.then((val)=>{
throw Error(“error!!“);
},(err)=>{
console.log(err)
});
所以Promise的错误处理,很容易被无声无息的吞掉。为了避免这个问题,通常我们都会在Promise串炼的末端加上catch()。
catch
catch方法其实跟then(undefined,onRejected)方法一样。两者的区别在于,then(undefined,onRejected)通常针对不同的错误处理作回复,而catch通常对错误作统一的回复。
const promise = new Promise((resolve,reject)=> {
resolve(4)
})
promise
.then((val)=> {
console.log(val)//4
return val + 2
})
.then((val)=> {
console.log(val)//6
throw new Error('error!')
})
.catch((error)=>{
console.log('err',error)
})
等同于:
const promise = new Promise((resolve,reject)=> {
resolve(4)
})
promise
.then((val)=> {
console.log(val)//4
return val + 2
})
.then((val)=> {
console.log(val)//6
throw new Error('error!')
})
.then(null,(error)=>{
console.log('err',error)
})
那如果我们同时写,then(undefined,onRejected)和catch会怎么样呢:
const promise = new Promise((resolve,reject)=> {
resolve(4)
});
promise
.then((val)=> {
console.log(val)//4
throw Error('error!')
})
.then(null,(error)=>{
console.log('err1',error.message);
return“I'm reject return”
})
.catch((err)=> {
console.log(“err2”,err.message);
return“I'm catch return”
})
.then((val)=>{
console.log(val);
},(error)=>{
console.log('err1',error.message);
})
//4
// err1 error!
// I'm reject return
可以看到说是谁在前面就会先显示(qqggcm)。
以上就是Promise的错误处理,如果有错误及来源未附上也欢迎留言指正,那么我们明天见。
学JS的心路历程-Promise(二)的更多相关文章
- 学JS的心路历程-Promise(三)
今天我们来说then一些特殊情况以及Promise.all()与Promise.race(). 我们都知道函式作为参数传入时,可以参照的方式传入,也能传入时执行拿回传值作使用: function us ...
- 学JS的心路历程-Promise(一)
今天在进入Promise代码之前,我们先来用个例子来解释Promise是什么. 未来值 假设我们今天来到快餐店,点了一个汉堡,付钱给店员. 点了餐点并付费,可以理解为我们发送了一个请求,希望得到一个回 ...
- 学JS的心路历程 -物件与原型(二)
昨天有提到说Object.setPrototypeOf可以指定一个物件为另一个物件的原型,但有想过到底这个原型,也就是[[Prototype]]最终会到何处吗? 答案是Object.prototype ...
- 学JS的心路历程-JS支持面向对象?(二)
昨天讲了面向对象的继承,今天我们来谈谈多态和封装吧! 多态polymorphism 抽象讲法解释,就是使用单一界面操作多种型态的物件 继承父类别,定义与父类别中相同的方法,但实作内容不同,称为复写(o ...
- 学JS的心路历程-函式(二)arguments
参数(argument)与函式参数(parameter) 在讨论函式时,很多人都会把这两个搞混,我自己也不例外. 虽然讲错别人也听得懂,但是我们还是要搞清楚这两个的定义到底是什么! 参数是当我们呼叫函 ...
- 学JS的心路历程Day28 - PixiJS -基础(二)
材质暂存(texture cache) 昨天有说到,图片要放入stage前,需要先把图片转成Sprite的特殊图片物件. 但是我们也可以先将图片放进材质暂存(texture cache). 什么是「材 ...
- 学JS的心路历程Day26 - PixiJS -入坑
后来知道也可以透过canvas让网页动起来! 而PixiJS是使用WebGL在canvas上绘制内容与制作动态 且同时有下列特色: 支持多点触控 掩码与混合模式 可外加WebGL滤镜 多装置支持 等等 ...
- 学JS的心路历程 -非同步执行
JS是单线程的语言,也就是说同一时间只会执行一行程序,所以如果一段程序执行过久就会造成阻塞(blocking)的现象,必须等到它结束后才能执行下一段程序. 举个例子来说,如果我们今天要买便当,但是老板 ...
- 学JS的心路历程 -函式(三)this
this是什么,取决于被呼叫的呼叫地点. 昨天有提到说,呼叫函式时候会传递隐含参数:arguments和this并讲解了arguments,今天我们就来探讨this吧! 什么是this 我们都会呼叫函 ...
随机推荐
- CS229 6.12 Neurons Networks from self-taught learning to deep network
self-taught learning 在特征提取方面完全是用的无监督的方法,对于有标记的数据,可以结合有监督学习来对上述方法得到的参数进行微调,从而得到一个更加准确的参数a. 在self-taug ...
- Java捕获异常的问题
---恢复内容开始--- 在Java编译过程中,有时候会出现输入未按照规定输入的情况,此时需要警告用户输入错误,这就会是程序运行过程中出现异常.异常就是可预测但是又没办法消除的一种错误.所以在编写过程 ...
- 小数据池 id
1. 小数据池, id() 小数据池针对的是: int, str, bool 在py文件中几乎所有的字符串都会缓存. id() 查看变量的内存地址 # id()函数可以帮我们查看一个变量的内存地址 # ...
- apache(httpd)配置
1.简单配置 1 监听地址 2 主页目录 3 别名 4 目录访问的身份验证 5 https 6 MPM(under linux) * 配置文件中路径.文件名均不支持中文. <<<&l ...
- uiautomator 代码记录 : 随机发送短信
package sms_test; import java.lang.*; import java.util.Random; import javax.microedition.khronos.egl ...
- load_basemap
map = new Map("map", { //basemap: "satellite", //center: [-85.743, 38.256], //zo ...
- cookie、localStorage、sessionStorage和会话控制机制
简介 cookie cookie的内容主要包括:名字Name.值Value.域Domain.路径Path.过期时间Expires/Max-Age.大小Size.HTTP.Secure.SameSite ...
- tensorflow实战系列(一)
最近开始整理一下tensorflow,准备出一个tensorflow实战系列,以飨读者. 学习一个深度学习框架,一般遵循这样的思路:数据如何读取,如如何从图片和标签数据中读出成tensorflow可以 ...
- linux驱动开发(三) 字符设备驱动框架
还是老规矩先上代码 demo.c #include <linux/init.h> #include <linux/module.h> #include <linux/ke ...
- jquery实现增删改(伪)-老男孩作业day13
使用jquery进行,文件的编写,实现自增id,删除,添加,编辑模式. jquery放在本地,src="jquery_js.js" 可以改成其他,或者在线的路径 readme &l ...