JavaScript 标准内置对象Promise使用学习总结
Javascript标准内置对象Promise使用学习总结
by:授客 QQ:1033553122
- 1. 基础用法
var condition = true;
let p = new Promise(function(resolve, reject){ // resolve, reject为两个回调函数,分别供使用者在函数执行成功和执行失败时调用
if (condition) { // 一些执行成功、失败的判断条件,暂且使用上述变量替代
// throw "exception"; // 如果此处代码代码未注释,即抛出异常,该异常值 exception将被传递给promiseObj.then函数参数列表中第二个参数--一个回调函数
resolve("执行成功"); // 如果resolve函数被调用,其函数实参将被传递给promiseObj.then函数参数列表中第一个参数--一个回调函数
} else {
// throw "exception"; // 如果此处代码代码未注释,即抛出异常,该异常值 exception将被传递给promiseObj.then函数参数列表中第二个参数--一个回调函数
reject("执行失败"); // 如果reject函数被调用,其函数实参将被传递给promiseObj.then函数参数列表中第二个参数--一个回调函数
}
})
p.then((data) => { // then函数接收两个参数--两个函数,分别在构造Promise对象定义的匿名函数(假设为func1)执行成功和执行失败时被调用(func1函数中,resolve被调用表示匿名函数执行成功,reject被调用、或者函数于resolve,reject被执行前,抛出了异常,表示匿名函数执行失败),第一个函数的参数接收来自resolve函数的实参,第二个函数的参数接收来自reject函数的实参、或者是函数抛出的异常值(异常优先于reject、resolve被抛出)
console.log(data);
}, (err) => {
console.log(err);
}
)
运行结果,控制台输出:
执行成功
- 2. 链式调用之.then
function testFunc(condition){
new Promise(function(resolve, reject){
if (condition) {
resolve("执行成功");
} else {
reject("执行失败");
}
}).then((data) => {
console.log(data);
return "then执行成功";
}, (err) => {
console.log(err);
return "then执行失败";
}).then(data => {//此处then函数接收两个参数--两个函数,分别在前一个then函数执行成功和执行失败时被调用。(前一个then函数参数列表中任意一个函数被调用,并且执行没抛出异常,表示执行成功,否则表示执行失败)。第一个函数的参数接收来自前一个then函数执行成功时的函数返回值,如果没有返回值则为undefined,第二个函数的参数接收来自前一个then函数执行失败时的函数返回值,如果没有返回值则为undfined,或者是then函数执行时抛出的异常值。
console.log("error:" + data);
}, err => {
console.log(err);
})
}
testFunc(true)
运行结果,控制台输出:
"执行成功"
"then执行成功"
testFunc(false)
"执行失败"
"error:then执行失败"
- 3. 链式调用之.catch
.catch将在new Promise时定义的匿名函数执行失败、.then函数执行失败,并且位于其后的then函数没有显示提供第二个参数(供失败时调用的函数)时被调用。可以简单理解为用于捕获前面发生的,且没有被任何then函数处理的错误。
例1:
function testFunc(condition){
new Promise(function(resolve, reject){
if (condition) {
resolve("执行成功");
} else {
reject("执行失败");
}
}).then(data => {
console.log(data);
}, err => {
console.log(err);
}).catch(err => {
console.log("error:" + err)
})
}
testFunc(false);
运行结果,控制台输出:
"执行失败"
例2:
function testFunc(condition){
new Promise(function(resolve, reject){
if (condition) {
resolve("执行成功");
} else {
reject("执行失败");
}
}).then((data) => {
console.log(data);
return "then执行成功";
}).then(data => {
console.log(data);
}).catch(err => {
console.log("error:" + err)
})
}
testFunc(false);
运行结果,控制台输出:
"error:执行失败"
例3:
function testFunc(condition){
new Promise(function(resolve, reject){
if (condition) {
resolve("执行成功");
} else {
reject("执行失败");
}
}).catch(err => {
console.log("error:" + err)
})
}
testFunc(false)
运行结果,控制台输出:
"error:执行失败"
- 4. Promise.all
Promise.all(iterable) 方法返回一个 Promise 实例,此实例在 iterable 参数内所有的 promise 都“完成(resolved)”或参数中不包含 promise 时回调完成(resolve);如果参数中 promise 有一个失败(rejected),此实例回调失败(reject),失败原因的是第一个失败 promise 的结果
例:
function testFunc1(condition){
return new Promise(function(resolve, reject){
if (condition) {
resolve("testFunc1执行成功");
} else {
reject("testFunc1执行失败");
}
});
}
function testFunc2(condition){
return new Promise(function(resolve, reject){
if (condition) {
resolve("testFunc2执行成功");
} else {
reject("testFunc2执行失败");
}
});
}
let result = Promise.all([testFunc2(true), testFunc1(true)]);
result.then((data) => {
console.log(data)
}).catch(err => {
console.log(err);
})
运行结果,控制台输出如下内容:
Array ["testFunc2执行成功", "testFunc1执行成功"]
let result = Promise.all([testFunc2(false), testFunc1(true)]);
result.then((data) => {
console.log(data)
}).catch(err => {
console.log(err);
})
运行结果,控制台输出如下内容:
"testFunc2执行失败"
说明:可以利用.all的特性,以并行执行多个异步操作,并且在一个回调中处理所有的返回数据(返回数据的顺序和传入参数数组的顺序对应)
参考链接:
https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Promise/all
JavaScript 标准内置对象Promise使用学习总结的更多相关文章
- JavaScript 标准内置对象
JavaScript 标准内置对象或称全局的对象(global objects)不要和 全局对象(global object)混淆.这里说的全局的对象是说在全局作用域里的对象,全局作用域包含了全局对象 ...
- 第一百零八节,JavaScript,内置对象,Global对象字符串编码解码,Math对象数学公式
JavaScript,内置对象,Global对象字符串编码解码,Math对象数学公式 学习要点: 1.Global对象 2.Math对象 ECMA-262对内置对象的定义是:"由ECMASc ...
- 深入浅出ES6的标准内置对象Proxy
Proxy是ES6规范定义的标准内置对象,可以对目标对象的读取.函数调用等操作进行拦截.一般来说,通过Proxy可以让目标对象"可控",比如是否能调用对象的某个方法,能否往对象添加 ...
- 一、JavaScript概述 二、JavaScript的语法 三、JavaScript的内置对象
一.JavaScript的概述###<1>JavaScript的概念 又称ECMAScript,和java没有任何关系 嵌入在HTML元素中的 被浏览器解释运行的 一种脚本语言. ###& ...
- JavaScript常用内置对象(window、document、form对象)
由于刚开始学习B/S编程,下面对各种脚本语言有一个宏观的简单认识. 脚本语言(JavaScript,Vbscript,JScript等)介于HTML和C,C++,Java,C#等编程语言之间.它的优势 ...
- JavaScript的内置对象(Global对象)
内置对象的定义 由 javaScript 实现提供的.不用自己创建,这些对象在 ECMAScript 程序执行之前就已经存在了. 意思就是说,开发人员不必显示地实例化内置对象:因为它们已经实例化了. ...
- javaScript的内置对象以及一些常用的方法
前几天,我们学习了JavaScript的入门课程,但是要想做网站,仅仅学会入门是不够的,今后的几天,我将带领大家精通JavaScript,希望大家好好学习! JS内置对象 String对象:字符串对象 ...
- javaScript的内置对象
javaScript 有11种内置对象: Array . String .Date .Math . Boolean .Number . Function .Global .Error . RegExp ...
- 【JavaScript】内置对象Math
Math是具有用于数学常数和函数的属性和方法一内置对象.不是函数对象. 描述编辑 不像其他的全局对象,Math不是一个构造函数.所有属性和方法Math都是静态的.你指的是常数pi为Math.PI你调用 ...
随机推荐
- UITableView 相关方法
最近闲来无事,总结一下 UITableViewDataSource和 UITableViewDelegate方法 UITableViewDataSource @required - (NSIntege ...
- uglify-js 和uglify-es
uglify-js 它不支持压缩 es6,参考github的issue It seems like uglify-js does not support es6? uglify-js在压缩代码时,遇到 ...
- java之方法的参数传递(值传递和引用传递)
方法,必须有其所在类或对象调用时才有意义,若方法有参数: 形参:方法声明时的参数: 实参:方法调用时实际传给形参的参数值: java的实参如何传入方法呢? 首先要明确:变量分为两大类:基础数据类型.引 ...
- Koa - 使用koa-multer上传文件(上传限制、错误处理)
前言 上传文件在开发中是很常见的操作,今天我选择使用koa-multer中间件来实现这一功能,除了上传文件外,我还会对文件上传进行限制,以及发生上传错误时的处理. 由于原来的 koa-multer 已 ...
- Grafana基础
一.Grafana基础 Grafana是一个开源的指标量监测和可视化工具.官方网站为:https://grafana.com/, 常用于展示基础设施的时序数据和应用程序运行分析.Grafana的das ...
- 【JS】379- 教你玩转数组 reduce
reduce 是数组迭代器(https://jrsinclair.com/articles/2017/javascript-without-loops/)里的瑞士军刀.它强大到您可以使用它去构建大多数 ...
- 【重温基础】16.JSON对象介绍
本文是 重温基础 系列文章的第十六篇. 今日感受:静. 系列目录: [复习资料]ES6/ES7/ES8/ES9资料整理(个人整理) [重温基础]1-14篇 [重温基础]15.JS对象介绍 本章节复习的 ...
- Centos 8 安装 Nginx
安装步骤: /* 1. 安装编译工具及库文件 */ yum -y install gcc automake autoconf libtool make && yum install g ...
- JVM系列三(垃圾收集器).
一.概述 1. 哪些内存需要回收 上篇文章 我们介绍了 Java 内存运行时区域的各个部分,其中程序计数器.虚拟机栈.本地方法栈三个区域随线程而生,随线程而灭,在这几个区域内就不需要过多考虑回收的问题 ...
- 大数据学习笔记——Java篇之网络编程基础
Java网络编程学习笔记 1. 网络编程基础知识 1.1 网络分层图 网络分层分为两种模型:OSI模型以及TCP/IP网络模型,前者模型分为7层,是一个理论的,参考的模型:后者为实际应用的模型,具体对 ...