JS常见错误(Error)及处理方案详解
1. 错误的类型
Error: 所有错误的父类型
错误的子类型包括:
- ReferenceError: 引用的变量不存在
- TypeError: 数据类型不正确的错误
- RangeError: 数据值不在其所允许的范围内
- SyntaxError: 语法错误
常见的内置错误:
(1)ReferenceError: 引用变量不存在
console.log(a) //ReferenceError: a is not defined
(2)TypeError: 数据类型不正确
var b = {}
b.xxx() //TypeError: b.xxx is not a function
(3)RangeError: 数据值不在其所允许的范围内
function fn(){ fn() } fn() //RangeError: Maximum call stack size exceeded
(4)SyntaxError: 语法错误
const c = """" //SyntaxError: Unexpected string
2. 错误处理
捕获错误: try ... catch
抛出错误: throw error
(1)捕获错误
try { let d console.log(d.xxx) } catch (error) { //可以通过调试查看error对象的属性(message属性: 错误相关信息;stack属性: 函数调用栈记录信息) console.log(error.message) //console.log(error.stack) } // 可以继续向下执行 console.log('出错之后')
(2)抛出错误
function something() { if (Date.now() % 2 === 1 ){ console.log('当前时间为奇数,可执行任务') } else { throw new Error('当前时间为偶数无法执行任务') } } //情况1 直接调用 something() //Error: 当前时间为偶数无法执行任务 console.log('something之后') //不会继续这句代码(没有对异常进行处理) //情况2 捕获处理异常 try { something() } catch(error) { console.log(error.message) }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
JavaScript Tips 使用DocumentFragment加快DOM渲染速度
大家在开发JavaScript应用的时候,如果遇到这种大量节点的情况,不妨将DocumentFragment作为一个备选的方案。2010-06-06js老生常谈之this,constructor ,prototype全面解析
下面小编就为大家带来一篇js老生常谈之this,constructor ,prototype。小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2016-04-04
最新评论