- try catch可以,比较方便
- .catch也可以
- .catch配合析构赋值也可以,比较优雅
在 async/await 方法中,可以使用 try-catch 块来处理异常。通过使用 try-catch,可以捕获异步操作中抛出的异常,并在 catch 块中进行适当的处理。
下面是一个 async/await 方法中使用 try-catch
处理异常的示例:
javascript
async function fetchData() {
try {
const response = await fetch("https://api.example.com/data");
if (!response.ok) {
throw new Error("Request failed");
}
const data = await response.json();
return data;
} catch (error) {
console.error("Error:", error);
throw error; // 可以选择重新抛出异常
}
}
async function process() {
try {
const result = await fetchData();
console.log("Result:", result);
} catch (error) {
console.error("Error:", error);
}
}
process();
在上述示例中,fetchData 函数是一个异步函数,内部使用 await 关键字等待 fetch 方法返回的 Promise 对象。如果请求失败(response.ok 为 false),则使用 throw 关键字抛出一个错误。在 catch 块中,可以捕获和处理这个错误,并进行适当的操作,比如打印错误信息或重新抛出异常。
在 process 函数中,使用 try-catch 块来捕获 fetchData 函数可能抛出的异常。如果 fetchData 函数中的异常被捕获到,则会在 catch 块中进行处理。
需要注意的是,在 async/await 方法中,如果不使用 try-catch 来处理异常,异步操作中抛出的错误将会被包装成一个被拒绝(rejected)的 Promise 对象,可以通过在调用 async 函数时使用 catch 方法来捕获这个错误。
async/await 方法提供了一种更直观和简洁的方式来处理异步操作,并且可以方便地使用 try-catch 来处理异常,使代码更易读和易于维护。
在 async/await 方法中,可以使用 .catch()
方法结合析构赋值(Destructuring Assignment)来进行异常处理。
下面是一个示例,展示了如何使用析构赋值和 .catch()
方法来处理异常:
javascript
async function fetchData() {
const response = await fetch("https://api.example.com/data");
if (!response.ok) {
throw new Error("Request failed");
}
const data = await response.json();
return data;
}
async function process() {
try {
const result = await fetchData();
console.log("Result:", result);
} catch ({ message }) {
console.error("Error:", message);
}
}
process().catch(error => {
console.error("Unhandled error:", error);
});
在上述示例中,fetchData 函数是一个异步函数,内部使用 await 关键字等待 fetch 方法返回的 Promise 对象。如果请求失败(response.ok 为 false),则使用 throw 关键字抛出一个错误。
在 process 函数中,使用 try-catch 块来捕获 fetchData 函数可能抛出的异常。在 catch 块中,使用析构赋值将错误对象的 message 属性解构出来,并进行适当的处理。
在调用 process 函数时,可以使用 .catch()
方法来捕获未处理的异常。这样可以确保在异步操作中抛出的异常能够被正确地捕获和处理。
通过使用析构赋值和 .catch()
方法,可以更方便地提取错误对象中的特定属性,并进行异常处理。这种方式可以使代码更加简洁和易读。