promise与async、await

promise与async、await

promise用法

  1. promise基本用法
let p1 = new Promise((resolve, reject) => {
	setTimeout(() => {
		resolve('p1-ok');
	}, 1000);
});

let p2 = Promise.resolve('p2-ok');

p1.then((res) => {
	console.log(res);// p1-ok
	return p2;
}).then((res) => {
	console.log(res);// p2-ok
	// ...
});
  1. Promise.all(Array[Promise] array, Function callback)
    只有当数组里所有的promise实例执行成功,才会变为成功状态,成功回调函数的参数是所有传入的promise的返回值组成的数组
let p1 = new Promise((resolve, reject) => {
	setTimeout(() => {
		resolve('p1-ok');
	}, 1000);
});

let p2 = Promise.resolve('p2-ok');

let p3 = Promise.reject(new Error('出错了!'));

let pAll = Promise.all([p1, p2, p3]);
pAll.then(res => {
	console.log('全部执行成功', res);
}).catch(err => {
	console.log('报错:' + err.message);// 报错:出错了!
}).finally(() => {
	console.log('Promise.all执行完毕');// Promise.all执行完毕
});
  1. Promise.race(Array[Promise] array, Function callback)
    只要数组中有一个成功,就整个执行成功,成功回调函数的参数为最先执行成功的promise实例的返回值
// ...
let pRace = Promise.race([p1, p2, p3]);
pRace.then(res => {
	console.log('至少一个执行成功', res);// 至少一个执行成功 p2-ok
});

async、await

async、await是generator函数的语法糖,是解决回调地狱的最新语法


async function demo() {
	let p1 = new Promise((resolve, reject) => {
		setTimeout(() => {
			resolve('p1-ok');
		}, 1000);
	});
	
	let p2 = Promise.resolve('p2-ok');
	
	let p3 = Promise.reject(new Error('出错了!'));

	try {
		let resAll = await Promise.all([p1, p2, p3]);
		console.log('resAll', resAll);
	} catch(err) {
		console.log('err', err.message);
	}
	
	let res = await Promise.race([p1, p2, p3]);
	console.log('race', res);
}

demo();
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值