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