JavaScript中,异常(Exception)和错误(Error)
JavaScript 是一种解释型语言,通常在浏览器中通过JavaScript引擎执行。最著名的两个引擎是:SpiderMonkey(由 Mozilla Firefox 使用)和V8(由 Google Chrome 和 Node.js 使用)。
错误(Error):编译或解析阶段的致命问题(如语法错误),程序无法运行。 处理方式:需开发者修复代码后才能运行,无法通过程序逻辑处理。
异常(Exception):运行时发生的可处理问题(如调用未定义方法、文件不存在),程序可继续运行。处理方式:通过try-catch结构捕获并恢复执行,避免程序终止。
Error对象及错误处理机制:https://blog.csdn.net/c_s_d_n_2009/article/details/149408647
JavaScript的finally块
JavaScript,finally块通常用于执行无论是否捕获到异常都必须执行的代码。
1、捕获了异常后,不再向上层调用者传递任何异常信息,使用finally处理。
async function fetchData(path) {
const data = await fetch(path).then((response) => {
if (!response.ok) {
throw new Error("Network response was not ok");
}
return response.json();
});
return data;
}
// 向上层调用者继续传递异常
async function getData() {
let data = {};
try {
// 模拟一个可能失败的操作
data = await fetchData("https://www.sequelize.cn/");
} catch (error) {
throw new Error("错误: " + error.message);
} finally {
// 使用了finally,
return data;
}
// return data;
}
async function main() {
try {
const data = await getData();
console.log("Data:", data);
} catch (error) {
console.error("Error fetching data:", error);
}
}
main();
输出: Data: {}
2、捕获了异常后,还想继续向上层调用者传递异常信息,不使用finally处理。
async function fetchData(path) {
const data = await fetch(path).then((response) => {
if (!response.ok) {
throw new Error("Network response was not ok");
}
return response.json();
});
return data;
}
// 向上层调用者继续传递异常
async function getData() {
let data = {};
try {
// 模拟一个可能失败的操作
data = await fetchData("https://www.sequelize.cn/");
} catch (error) {
throw new Error("错误: " + error.message);
}
// finally {
// // 使用了finally,
// return data;
// }
return data;
}
async function main() {
try {
const data = await getData();
console.log("Data:", data);
} catch (error) {
console.error("Error fetching data:", error);
}
}
main();
输出: Error fetching data: Error: 错误: Unexpected token '<', "<!doctype "... is not valid JSON