标签:并且 syn func 构造函数 cat 处理 报错 异步操作 new
//ES6 规定,Promise对象是一个构造函数,用来生成Promise实例。
const p = new Promise(function(resolve,reject){
if(success){
resolve(‘成功的结果‘)
}else{
reject(‘失败的结果‘)
}
})
p.then(function (res) {
// 接收resolve传来的数据,做些什么
},function (err) {
// 接收reject传来的数据,做些什么
})
p.catch(function (err) {
// 接收reject传来的数据或者捕捉到then()中的运行报错时,做些什么
})
p.finally(function(){
// 不管什么状态都执行
})
const p = Promise.all([p1, p2, p3])
p的状态由p1、p2、p3决定,分成两种情况。
(1)只有p1、p2、p3的状态都变成fulfilled,p的状态才会变成fulfilled,此时p1、p2、p3的返回值组成一个数组,传递给p的回调函数。
(2)只要p1、p2、p3之中有一个被rejected,p的状态就变成rejected,此时第一个被reject的实例的返回值,会传递给p的回调函数。
function* helloGenerator() {
yield ‘hello‘;
yield ‘Generator‘;
return ‘over‘;
}
let hw = helloGenerator();
hw.next()//{value:"hello",done:false}
hw.next()//{value:"Generator",done:false}
hw.next()//{value:"over",done:true}
hw.next()//{value:undfined,done:true}
function get1(){
return new Promise((resolve,reject)=>{
setTimeout(()=>{resolve(1)},2000)
})
}
async function getSet(){
const n = await get1()
//const n = await ‘111‘
return n
}
getSet().then(console.log)
async function f() {
try {
await Promise.reject(‘出错了‘);
} catch(e) {
}
return await Promise.resolve(‘hello world‘);
}
f().then(v => console.log(v))
//此处省略getFoo(), getBar()两个函数
// 写法一
async function getSet(){
let [foo, bar] = await Promise.all([getFoo(), getBar()]);
return [foo, bar]
}
// 写法二
async function getSet(){
let fooPromise = getFoo();
let barPromise = getBar();
let foo = await fooPromise;
let bar = await barPromise;
return [foo, bar]
}
*文章参考ECMAScript 6 入门 *
标签:并且 syn func 构造函数 cat 处理 报错 异步操作 new
原文地址:https://www.cnblogs.com/mouseleo/p/10801665.html