JS常見錯(cuò)誤(Error)及處理方案詳解
1. 錯(cuò)誤的類型
Error: 所有錯(cuò)誤的父類型
錯(cuò)誤的子類型包括:
ReferenceError: 引用的變量不存在 TypeError: 數(shù)據(jù)類型不正確的錯(cuò)誤 RangeError: 數(shù)據(jù)值不在其所允許的范圍內(nèi) SyntaxError: 語法錯(cuò)誤常見的內(nèi)置錯(cuò)誤:
(1)ReferenceError: 引用變量不存在
console.log(a) //ReferenceError: a is not defined
(2)TypeError: 數(shù)據(jù)類型不正確
var b = {}b.xxx() //TypeError: b.xxx is not a function
(3)RangeError: 數(shù)據(jù)值不在其所允許的范圍內(nèi)
function fn(){fn()}fn() //RangeError: Maximum call stack size exceeded
(4)SyntaxError: 語法錯(cuò)誤
const c = '''' //SyntaxError: Unexpected string
2. 錯(cuò)誤處理
捕獲錯(cuò)誤: try ... catch
拋出錯(cuò)誤: throw error
(1)捕獲錯(cuò)誤
try { let d console.log(d.xxx)} catch (error) { //可以通過調(diào)試查看error對象的屬性(message屬性: 錯(cuò)誤相關(guān)信息;stack屬性: 函數(shù)調(diào)用棧記錄信息) console.log(error.message) //console.log(error.stack)}// 可以繼續(xù)向下執(zhí)行console.log(’出錯(cuò)之后’)
(2)拋出錯(cuò)誤
function something() { if (Date.now() % 2 === 1 ){ console.log(’當(dāng)前時(shí)間為奇數(shù),可執(zhí)行任務(wù)’) } else { throw new Error(’當(dāng)前時(shí)間為偶數(shù)無法執(zhí)行任務(wù)’) }}//情況1 直接調(diào)用something() //Error: 當(dāng)前時(shí)間為偶數(shù)無法執(zhí)行任務(wù)console.log(’something之后’) //不會(huì)繼續(xù)這句代碼(沒有對異常進(jìn)行處理)//情況2 捕獲處理異常try { something()} catch(error) { console.log(error.message)}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 淺談XML Schema中的elementFormDefault屬性2. jsp學(xué)習(xí)之scriptlet的使用方法詳解3. ASP.NET MVC獲取多級(jí)類別組合下的產(chǎn)品4. ASP.NET MVC實(shí)現(xiàn)橫向展示購物車5. ThinkPHP5 通過ajax插入圖片并實(shí)時(shí)顯示(完整代碼)6. Docker 容器健康檢查機(jī)制7. python實(shí)現(xiàn)PolynomialFeatures多項(xiàng)式的方法8. ASP.NET MVC使用Session會(huì)話保持表單狀態(tài)9. Python列表嵌套常見坑點(diǎn)及解決方案10. 解決python使用list()時(shí)總是報(bào)錯(cuò)的問題
