JavaScript 常见错误
本章指出了 JavaScript 中一些常见的错误。
意外使用赋值运算符
如果程序员在 if 语句中意外使用赋值运算符 (=
),而不是比较运算符 (==
),JavaScript 程序可能会产生意想不到的结果。
此 if
语句返回 false
(预期结果),因为 x 不等于 10
let x = 0;
if (x == 10)
亲自尝试 »
此 if
语句返回 true
(可能不是预期结果),因为 10 为真
let x = 0;
if (x = 10)
亲自尝试 »
此 if
语句返回 false
(可能不是预期结果),因为 0 为假
let x = 0;
if (x = 0)
亲自尝试 »
赋值总是返回赋值的值。
期望宽松比较
在常规比较中,数据类型无关紧要。此 if
语句返回 true
let x = 10;
let y = "10";
if (x == y)
亲自尝试 »
在严格比较中,数据类型很重要。此 if
语句返回 false
let x = 10;
let y = "10";
if (x === y)
亲自尝试 »
忘记 switch
语句使用严格比较是一个常见的错误
此 case switch
将显示一个警报
let x = 10;
switch(x) {
case 10: alert("Hello");
}
亲自尝试 »
此 case switch
将不会显示一个警报
let x = 10;
switch(x) {
case "10": alert("Hello");
}
亲自尝试 »
混淆加法和字符串连接
加法是关于数字的加法。
字符串连接是关于字符串的加法。
在 JavaScript 中,这两种操作都使用相同的 +
运算符。
因此,将数字作为数字添加会产生与将数字作为字符串添加不同的结果。
let x = 10;
x = 10 + 5; // 现在 x 是 15
let y = 10;
y += "5"; // 现在 y 是 "105"
亲自尝试 »
当添加两个变量时,可能难以预测结果。
let x = 10;
let y = 5;
let z = x + y; // 现在 z 是 15
let x = 10;
let y = "5";
let z = x + y; // 现在 z 是 "105"
亲自尝试 »
误解浮点数
JavaScript 中的所有数字都以 64 位浮点数 (浮点数) 存储。
所有编程语言,包括 JavaScript,在处理精确的浮点值时都存在困难。
let x = 0.1;
let y = 0.2;
let z = x + y // z 的结果将不会是 0.3
亲自尝试 »
为了解决上述问题,可以进行乘除运算。
拆分 JavaScript 字符串
JavaScript 允许将语句拆分成两行。
但是,在字符串中间拆分语句将无法正常工作。
必须使用“反斜杠”,如果必须在字符串中拆分语句。
将分号放错位置
由于分号放错位置,即使 x 的值不同,此代码块也会执行。
if (x == 19);
{
// 代码块
}
亲自尝试 »
拆分 return 语句
在 JavaScript 中,默认行为是在行尾自动关闭语句。
因此,这两个示例将返回相同的结果。
JavaScript 还允许将语句拆分成两行。
因此,示例 3 也将返回相同的结果。
但是,如果像这样将 return 语句拆分成两行,会发生什么?
该函数将返回 undefined
!
为什么?因为 JavaScript 认为您的意思是
解释
如果语句不完整,例如
let
JavaScript 会尝试通过读取下一行来完成语句。
power = 10;
但由于此语句是完整的
return
JavaScript 会自动将其关闭,如下所示。
return;
之所以会发生这种情况,是因为在 JavaScript 中,用分号关闭(结束)语句是可选的。
JavaScript 会在行尾关闭 return 语句,因为这是一个完整的语句。
永远不要拆分 return 语句。
使用命名索引访问数组
许多编程语言支持使用命名索引的数组。
使用命名索引的数组被称为关联数组(或哈希表)。
JavaScript 不支持使用命名索引的数组。
在 JavaScript 中,数组使用数字索引:
示例
const person = [];
person[0] = "John";
person[1] = "Doe";
person[2] = 46;
person.length; // person.length 将返回 3
person[0]; // person[0] 将返回 "John"
亲自尝试 »
在 JavaScript 中,对象使用命名索引。
如果您使用命名索引访问数组,JavaScript 将重新定义数组为标准对象。
自动重新定义后,数组方法和属性将产生未定义或不正确的结果。
示例
const person = [];
person["firstName"] = "John";
person["lastName"] = "Doe";
person["age"] = 46;
person.length; // person.length 将返回 0
person[0]; // person[0] 将返回 undefined
亲自尝试 »
以逗号结尾的定义
对象和数组定义中的尾部逗号在 ECMAScript 5 中是合法的。
对象示例
person = {firstName:"John", lastName:"Doe", age:46,}
数组示例
points = [40, 100, 1, 5, 25, 10,];
警告!!
Internet Explorer 8 将崩溃。
JSON 不允许尾部逗号。
JSON
person = {"firstName":"John", "lastName":"Doe", "age":46}
JSON
points = [40, 100, 1, 5, 25, 10];
undefined 不等于 Null
JavaScript 对象、变量、属性和方法可以是 undefined
。
此外,空 JavaScript 对象的值可以是 null
。
这可能会使测试对象是否为空变得有点困难。
可以通过测试类型是否为 undefined
来测试对象是否存在。
但不能测试对象是否为 null
,因为如果对象为 undefined
,这将引发错误。
错误
if (myObj === null)
为了解决这个问题,必须测试对象是否不为 null
且不为 undefined
。
但这仍然可能会引发错误。
错误
if (myObj !== null && typeof myObj !== "undefined")
因此,必须先测试是否不为 undefined
,然后才能测试是否不为 null
。