JavaScript yield与异步编程
2025年3月30日 22:08
什么是 yield? yield 关键字只能在生成器函数中使用。生成器函数是一种特殊的函数,使用 function* 声明。当生成器函数执行到 yield 表达式时,它会暂停执行,并将 yield 后
console.log("Hello World'; // 缺少闭合引号
ReferenceError
:访问未声明变量(如console.log(undeclaredVar)
)。TypeError
:对错误类型执行操作(如null.f()
)。RangeError
:数值越界(如new Array(-1)
)。console.assert()
进行运行时断言。try {
let num = JSON.parse('{invalid json}');
console.log(num);
} catch (error) {
console.error("捕获错误:", error.message);
} finally {
cleanupResources(); // 无论成败都会执行
}
• 抛出语义化错误:
class NetworkError extends Error {
constructor(url) {
super(`请求 ${url} 失败`);
this.code = "NETWORK_FAILURE";
}
}
throw new NetworkError("https://api.example.com");
• 优势:通过error.code
分类处理不同错误。
• 避免在循环内滥用try/catch:V8引擎对try
块优化较弱,高频调用可能拖慢性能。
// 错误示范:
for (let i = 0; i < 1e6; i++) {
try { /* 可能失败的操作 */ }
catch {}
}
// 正确做法:将try/catch外移至循环外层
fetchData().then(res => { ... }); // 缺少.catch()
Uncaught (in promise) Error
,导致全局崩溃。.then().catch()
。window.addEventListener('unhandledrejection', e => {
reportToServer(e.reason); // 上报至监控系统
});
async function loadUserData() {
try {
const data = await fetch('/api/user');
if (!data.ok) throw new Error('状态码异常');
} catch (error) {
showToast(`加载失败:${error.message}`);
}
}