Promise使用

这篇博客深入探讨了Promise的基本用法,包括resolve和reject的处理。接着,文章介绍了async/await的组合使用,展示了如何在try-catch块中优雅地处理异步错误。通过实例,解释了如何在异步操作中获取和处理resolve和reject的结果。

1、一般使用

// resolve
new Promise((resolve,reject) => {
    resolve(2222);
}).then(res => {
    // 获取resolve的内容
    console.log(res); // 2222;
})


// reject
new Promise((resolve,reject) => {
    reject('error');
}).then(res => {
    // 获取resolve的内容

}).catch(err => {
    // 获取reject的内容
    console.log(err ); // 'error';
})

2、async、await和try、catch和promise的组合使用

const getVal = () => {
    return new Promise((resolve,reject) => {
        resolve(2222);
    })
}

const getError = () => {
    return new Promise((resolve,reject) => {
        reject('error');
    })
}


const tryCatchVal = async() => {
    try{
        const val = await getVal();
        console.log(val); // 2222
        const error= await getError ();     
    }catch(err){
        console.log(err); // 'error'
    }
}

tryCatchVal();

### JavaScript Promise 使用示例 #### 创建简单的 Promise 实例 可以使用 `new Promise` 构造函数来创建一个 Promise 对象。此构造函数接收一个带有 resolve 和 reject 参数的执行器函数作为参数。 ```javascript const myFirstPromise = new Promise((resolve, reject) => { setTimeout(() => { resolve("成功完成"); }, 1000); }); myFirstPromise.then(result => console.log(result)); // 输出: 成功完成 ``` #### 处理多个 Promise 的状态变化 为了更高效地管理多个异步请求,JavaScript 提供了几种方法用于组合多个 Promises: - **all**: 当所有的 promises 都 fulfilled 或者有一个被 rejected 后触发回调。 ```javascript const promiseA = Promise.resolve(1); const promiseB = Promise.resolve(2); Promise.all([promiseA, promiseB]) .then(values => console.log(values)) // 输出: [1, 2] ``` - **race**: 只要其中任意一个 promise 完成就会立即返回该结果。 ```javascript const promiseC = new Promise(resolve => setTimeout(resolve, 500, '短延时')); const promiseD = new Promise(resolve => setTimeout(resolve, 1000, '长延时')); Promise.race([promiseC, promiseD]) .then(value => console.log(value)); // 输出: 短延时 ``` - **allSettled**: 所有的 promises 不论是 fulfill 还是 reject ,都会等到全部结束才继续往下走,并给出每个 promise 结果的信息。 ```javascript const promiseE = Promise.resolve('成功'); const promiseF = Promise.reject('失败'); Promise.allSettled([promiseE, promiseF]) .then(results => results.forEach( result => result.status === 'fulfilled' ? console.log(`成功: ${result.value}`) : console.error(`失败: ${result.reason}`) )); // 输出: // 成功: 成功 // 错误: 失败 ``` - **any**: 返回第一个成功的 promise ;如果所有都失败,则抛出 AggregateError 异常。 ```javascript const promiseG = Promise.reject(new Error('错误一')); const promiseH = Promise.reject(new Error('错误二')); const promiseI = Promise.resolve('第三个成功'); Promise.any([promiseG, promiseH, promiseI]) .then(value => console.log(`至少一个成功: ${value}`)) .catch(errors => console.error('全都不幸失败', errors)); // 输出: 至少一个成功: 第三个成功 ``` 这些例子展示了如何利用不同的方式去控制和协调多个异步任务之间的关系[^3]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值