前端报错手册

219 阅读5分钟

错误种类:

· 代码错误:这种错误浏览器会报错,可以根据具体的错误类型去排错。 

· 逻辑错误:这种错误浏览器不会报错,但是可以通过打印日志,或者打断点进行调试排错。

一,代码错误

1.1 SyntaxError(语法错误)

报错为:Uncaught Syntaxerror:相关信息提示。表示解析代码时发生的语法错误,即写的代码不符合js编码规则。我们可以根据后面的信息提示去修改错误,当然,语法错误,浏览器会直接报错,整个代码都不会执行。

 

如下:

第一种:变量名错误导致;

第二种:缺少括号

 

声明变量:var / let / const / function,当创建一个变量时会在内存中的栈区开辟一个新的空间。


变量命名规则和规范:
规则:
1.由字母、数字、下划线、$符号组成,不能以数字开头
2.不能是关键字和保留字,例如:for,while,this,name
3.区分大小写


规范:
1.变量名必须有意义
2.遵守驼峰命名法
3.建议不要用$作为变量名

×Uncaught SyntaxError: Invalid or unexpected token

×Uncaught SyntaxError: missing) after argument list

1.2 ReferenceError(引用错误)

报错为:Uncaught ReferenceError:***,表示使用了没有定义的变量,错误之前的代码会执行,之后代码不会执行。

 

如下:

第一种:引用了一个不存在的变量;

第二种:将变量赋值给一个无法被赋值的对象;

第三种:使用JSON.parse进行解析json字符串时,解析的内容不合法。

 

×Uncaught ReferenceError: a is not defined

×Uncaught ReferenceError: Invalid left-hand side in assignment

×Uncaught SyntaxError: Unexepcted token u in JSON at position 0

1.3 RangeError(范围错误)

RangeError是当一个值超出有效范围时发生的错误。

主要有几种情况,一是数组长度为负数,二是Number对象的方法参数超出范围,以及函数堆栈超过最大值。

 

×Uncaught RangeError: Invalid array length

1.4 TypeError(类型错误)

1.4.1 变量或参数不是预期类型

比如,对字符串、布尔值、数值等原始类型的值使用new命令,就会抛出这种错误,因为new命令的参数应该是一个构造函数。

×Uncaught TypeError: 123 is not a constructor

×Uncaught TypeError: a is not function

1.4.2调用对象不存在的方法

以下的错误是因为变量**前面的那个变量是undefined/null。

 

×Uncaught TypeError: Cannot read property 'aa' of undefined

×Uncaught TypeError: Cannot set property 'name' undefined

×Uncaught TypeError: Cannot set property 'age' of null

1.5 URLError(URL错误)

URIError是URI相关函数的参数不正确时抛出的错误,主要涉及encodeURI()、decodeURI()、encodeURIComponent()、decodeURIComponent()、escape()和unescape()这六个函数。这些API的使用太少了,因此这种错误在我们日常开发中很少遇到。

 

×Uncaught URIError: URI malformed

1.6 EvalError(eval错误)

eval函数没有被正确执行时,会抛出EvalError错误。该错误类型已经不再在ES5中出现了,只是为了保证与以前代码兼容,才继续保留。因此这种错误在我们日常开发中也基本不会遇到。

1.7 Error(基类型)

Error 是基类型,其他六种错误类型都继承自该类型。因此,所有错误类型共享了一组相同的属 性(错误对象中的方法全是默认的对象方法)。 Error 类型的错误很少见,如果有也是浏览器抛出的; 这个基类型的主要目的是供开发人员抛出自定义错误。如下:

×Uncaught Error: 出错了!

×Uncaught RangeError: 出错了,变量超出有效范围!

×Uncaught TypeError: 出错了,变量类型无效!

二,逻辑错误

2.1类型转换错误

类型转换错误发生在使用某个操作符,或者使用其他可能会自动转换值的数据类型的语言结构时。 在使用相等(==)和不相等(!=)操作符,或者在 if 、 for 及 while 等流控制语句中使用非布尔值时, 最常发生类型转换错误。

 

因此建议使用全等(===)和不全等(!==)操作符,以避免类型转换。

 

alert(5 == "5"); //true

alert(5 === "5"); //false

alert(1 == true); //true

alert(1 === true); //false

2.2数据类型错误

JavaScript 是松散类型的,也就是说,在使用变量和函数参数之前,不会对它们进行比较以确保它 们的数据类型正确。为了保证不会发生数据类型错误,只能依靠开发人员编写适当的数据类型检测代码。 建议大家可以学习使用typescript,它是一种强类型的语言,可以设置变量的具体类型,在前端开发中使用会极大的减少我们开发的bug,并且方便维护。

 

function getQueryString (url) {

  if (typeof url == "string") { // 通过检查类型确保安全

    let pos = url.indexOf("?")

    if (pos > -1) {

      return url.substring(pos + 1)

    }

  }

  return ""

}

 

// 这个函数首先检查了传入的值是不是字符串。这样,就确保了函数不会因为接收到非字符串值而导致错误。

2.3通信错误

2.3.1 ajax请求的地址url不正确

会报404的状态码,找不到页面

2.3.2发送的数据错误

会报400的状态码,一般为参数错误

三,浏览器的其他报错

·XMLHttpRequest cannot load http://. No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'http://' is therefore not allowed access.

 

进行异步请求时,产生跨域了

 

·Illegal break statement

 

出现了非法语句

 

·GET file:///****::ERR_FILE_NOT_FOUND

 

找不到引入的.js文件。可能原因:没有引入文件,或者js文件名字拼写错误(比如,少了文件后缀.)

·Failed to load resource: the server responded with a status of 404 (Not Found)

 

文件没有被找到,说明文件引用的路径有问题,或文件损坏

四,补充

欢迎大家评论,新人第一天 ^ _ ^