javascript中error错误类型
javascript中error错误类型
javascript中error错误类型一、Error
基类型,其他错误类型都继承自该类型。因此,所有错误类型共享了一组相同的属性。Error类型的错误很少见,如果有也是浏览器抛出的;这个基类型的主要目的是供开发人员抛出自定义错误
二、EvalError (eval错误)
eval函数没有被正确执行时,会抛出EvalError错误。该错误类型已经不再在ES5中出现了,只是为了保证与以前代码兼容,才继续保留
三、RangeError (范围错误)
RangeError类型的错误会在一个值超出相应范围时触发,主要包括超出数组长度范围以及超出数字取值范围等,例如:数组长度为负数、Number对象的方法参数超出范围、函数堆栈超过最大值
new Array(-1);//Uncaught RangeError: Invalid array length
new Array(Number.MAX_VALUE);//Uncaught RangeError: Invalid array length
(1234).toExponential(21);//Uncaught RangeError: toExponential() argument must be between 0 and 20
(1234).toExponential(-1);////Uncaught RangeError: toExponential() argument must be between 0 and 20
四、ReferenceError (引用错误)
1、引用一个不存在的变量时,会触发ReferenceError(引用错误)
a;//Uncaught ReferenceError: a is not defined
1++;//Uncaught ReferenceError: Invalid left-hand side expression in postfix operation
2、另一种触发场景是,将一个值分配给无法分配的对象,比如对函数的运行结果或者this赋值。
console.log() = 1 // ReferenceError: Invalid left-hand side in assignment
this = 1 // ReferenceError: Invalid left-hand side in assignment
五、SyntaxError (语法错误)
当不符合语法规则时,会抛出SyntaxError(语法错误)
//变量名错误
var 1a;//Uncaught SyntaxError: Unexpected number
// 缺少括号
console.log 'hello');//Uncaught SyntaxError: Unexpected string
六、TypeError (类型错误)
1、在变量或参数不是预期类型时,或者在访问不存在的方法时 都会导致TypeError类型错误。
2、比如,对字符串、布尔值、数值等原始类型的值使用new命令,就会抛出这种错误,因为new命令的参数应该是一个构造函数。
var o = new 10;//Uncaught TypeError: 10 is not a constructor
var obj = {}; obj.unknownMethod() // TypeError: undefined is not a function
alert('name' in true);//Uncaught TypeError: Cannot use 'in' operator to search for 'name' in true
Function.prototype.toString.call('name');//Uncaught TypeError: Function.prototype.toString is not generic
七、URIError (URI错误)
URIError是URI相关函数的参数不正确时抛出的错误,主要涉及encodeURI()、decodeURI()、encodeURIComponent()、decodeURIComponent()、escape()和unescape()这六个函数。
decodeURI('%2');// URIError: URI malformed
- javascript如何获取后台数据(JavaScript实现异步获取表单数据)
- js绘制平滑路径(如何利用Javascript生成平滑曲线详解)
- javascript的执行顺序
- js实现div(javascript拖曳互换div的位置实现示例)
- javascript 函数生命周期(JavaScript sleep睡眠函数的使用)
- js实时获取页面宽度(JavaScript获取网页的宽高及如何兼容详解)
- javascript中需要注意的几个细节
- javascript如何建立一个静态变量(JavaScript中子函数访问外部变量的3种解决方法)
- javascript函数的递归调用记得加上return
- javascript页面滚动窗口(javascript实现简单滚动窗口)
- javascript如何操作文档元素(JavaScript操作元素实例大全)
- js三级联动说明(基于JavaScript实现省市联动效果)
- pyqt5加载chrome浏览器(PyQt5内嵌浏览器注入JavaScript脚本实现自动化操作的代码实例)
- html基础知识javascript(JavaScript+html实现前端页面滑动验证)
- javascript五大继承方式(原生Javascript实现继承方式及其优缺点详解)
- js回调函数原理(关于JavaScript回调函数的深入理解)
- 董元奔吟咏历代文人 1012新旧均可 全椒人张璪 1022 -1093(董元奔吟咏历代文人)
- 泪目 这位 刷屏 的英雄,是全椒人的骄傲(泪目这位刷屏)
- 人从众 火炎焱 全椒再现 正月十六走太平 的魅力(人从众火炎焱全椒再现)
- 官宣 全椒籍明星许海峰 奚秀兰 方芳 王璐瑶携手回家 走太平(全椒籍明星许海峰)
- 以前全椒人是怎么过冬的 满满都是回忆(以前全椒人是怎么过冬的)
- NVIDIA显卡份额冲上88 A饭发愁 游戏优化恐没A卡份了(NVIDIA显卡份额冲上88A饭发愁)
热门推荐
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9