new Promise 直接catch
时间: 2024-05-17 16:10:45 浏览: 102
在 JavaScript 中,Promise 是一种用于异步编程的对象,它代表了一个可能还没有完成的异步操作并可以返回其结果或错误信息。当 Promise 的异步操作抛出异常时,可以通过 .catch() 方法捕获异常并进行处理。
当我们使用 new Promise() 创建一个 Promise 实例时,我们可以在其内部定义一个异步操作,并通过 resolve() 和 reject() 方法来分别返回异步操作成功和失败的结果。在使用 Promise 时,通常我们会链式调用 .then() 和 .catch() 方法来处理异步操作的结果和异常。但是,如果我们直接在 new Promise() 内部使用 .catch() 方法来捕获异常,则会将捕获到的异常传递到 Promise 实例的 reject() 方法中,并最终触发 Promise 的失败状态。
以下是使用 new Promise() 直接 catch 异常的示例代码:
```
new Promise((resolve, reject) => {
// 异步操作
throw new Error('Something went wrong');
}).catch((error) => {
console.error(error);
});
```
在上面的示例中,当执行到 throw new Error('Something went wrong') 时,会抛出一个错误,并被 .catch() 方法捕获并输出错误信息。
相关问题
Promise的catch
Promise的catch方法用于捕获Promise链中的错误。它会在Promise链中的任何一个then方法中发生错误时被调用。catch方法接收一个回调函数作为参数,该回调函数会在错误发生时被调用,并接收错误对象作为参数。
以下是两个使用Promise的catch方法的例子:
1. 捕获reject错误:
```javascript
const promise = new Promise((resolve, reject) => {
reject("rejected status");
});
promise
.then(res => {})
.then(res => {
throw new Error("then error message");
})
.catch(err => {
console.log("err:", err); // 输出:err: rejected status
});
```
2. 捕获then错误:
```javascript
const promise = new Promise((resolve, reject) => {
resolve('22222');
});
promise
.then(res => {})
.then(res => {
throw new Error("then error message");
})
.catch(err => {
console.log("err:", err); // 输出:err: then error message
});
```
手写promise.catch
手写Promise的`.catch`方法通常用于处理Promise链中的错误情况。在JavaScript中,当你有一个返回Promise的对象,你可以添加`.catch`方法来捕获并处理这个Promise在执行过程中可能出现的错误。当原Promise拒绝(即抛出异常),`.catch`会接收到那个错误,并允许你在回调函数中处理它,使得程序不会因为未被捕获的错误而中断。
以下是一个简单的例子:
```javascript
function myFunction() {
return new Promise((resolve, reject) => {
// 模拟可能会失败的操作
if (Math.random() > 0.5) {
reject(new Error('Something went wrong'));
} else {
resolve('Success!');
}
});
}
myFunction()
.then(result => console.log(result)) // 成功时的处理
.catch(error => console.error('Error caught:', error)); // 错误时的处理
```
在这个例子中,如果`myFunction`内部操作失败,`reject`会被调用,然后`.catch`会捕获到这个错误并打印出来。
阅读全文