JavaScript 常见错误
本章指出一些常见的 JavaScript 错误。
意外使用赋值运算符
如果程序员在 if
语句中意外使用赋值运算符(=
)而不是比较运算符(===
),JavaScript 程序可能会产生一些无法预料的结果。
这条 if
语句返回 false
(正如预期),因为 x 不等于 10:
var x = 0; if (x == 10)
这条 if
语句返回 true
(也许不像预期),因为 10 为 true:
var x = 0; if (x = 10)
这条 if
语句返回 false
(也许不像预期),因为 0 为 false:
var x = 0; if (x = 0)
赋值总是返回赋值的值。
期望松散的比较
在常规比较中,数据类型不重要。这条 if
语句返回 true
:
var x = 10; var y = "10"; if (x == y)
在严格比较中,数据类型确实重要。这条 if
语句返回 false
:
var x = 10; var y = "10"; if (x === y)
有一个常见的错误是忘记在 switch
语句中使用严格比较:
这条 switch
语句会显示提示框:
var x = 10; switch(x) { case 10: alert("Hello"); }
这条 switch
语句不会显示提示框:
var x = 10; switch(x) { case "10": alert("Hello"); }
令人困惑的加法和级联
加法用于加数值。
级联(Concatenation)用于加字符串。
在 JavaScript 中,这两种运算均使用相同的 +
运算符。
正因如此,将数字作为数值相加,与将数字作为字符串相加,将产生不同的结果:
var x = 10 + 5; // x 中的结果是 15 var x = 10 + "5"; // x 中的结果是 "105"
如果是两个变量相加,很难预测结果:
var x = 10; var y = 5; var z = x + y; // z ƙarfi 15 var x = 10; var y = "5"; var z = x + y; // z ƙarfi ƙarar "105"
Kara ƙa ƙara ƙara
Dijittan na ƙirki ƙarfi 64 ƙarfi浮点数(Floats)。
所有编程语言,包括 JavaScript,都存在处理浮点值的困难:
var x = 0.1; var y = 0.2; var z = x + y // z 中的结果并不是 0.3
为了解决上面的问题,请使用乘除运算:
实例
var z = (x * 10 + y * 10) / 10; // z 中的结果将是 0.3
对 JavaScript 字符串换行
JavaScript 允许您把一条语句换行为两行:
例子 1
var x = "Hello World!";
但是,在字符串中间来换行是不对的:
例子 2
var x = "Hello World!";
如果必须在字符串中换行,则必须使用反斜杠:
例子 3
var x = "Hello \ World!";
对 return 语句进行换行
在一行的结尾自动关闭语句是默认的 JavaScript 行为。
正因如此,下面两个例子返回相同的结果:
例子 1
function myFunction(a) { var power = 10 return a * power }
例子 2
function myFunction(a) { var power = 10; return a * power; }
JavaScript 也允许您将一条语句换行为两行。
正因如此,例子 3 也将返回相同的结果:
例子 3
function myFunction(a) { var power = 10; return a * power; }
但是,如果把 return
语句换行为两行会发生什么呢:
例子 4
function myFunction(a) { var power = 10; return a * power; }
此函数将返回 undefined
!
为什么呢?因为 JavaScript 认为你的意思是:
例子 5
function myFunction(a) { var power = 10; return; a * power; }
解释
如果某条语句是不完整的:
var
JavaScript 将通过读取下一行来完成这条语句:
power = 10;
但是由于这条语句是完整的:
return
JavaScript 会自动关闭该语句:
return;
发生这种情况是因为,在 JavaScript 中,用分号来关闭(结束)语句是可选的。
JavaScript 会在行末关闭 return
语句,因为它本身就是一条完整的语句。
所以,绝不要对 return
语句进行换行。
通过命名索引来访问数组
da yawa ɗanin ɗanin ɗanin ɗanin ɗanin ɗanin ɗanin ɗanin ɗanin ɗanin ɗanin ɗanin.
tassaki da ɗanin ɗanin ɗanin ɗanin ɗanin ɗanin ɗanin ɗanin ɗanin ɗanin.
JavaScript baya ɗanin ɗanin.tassaki da ɗanin ɗanin ɗanin.
a cikin JavaScript,tassakika ɗauka.numeric index:
实例
var person = []; person[0] = "Bill"; person[1] = "Gates"; person[2] = 46; var x = person.length; // person.length za a iya ɗauka 3 var y = person[0]; // person[0] za a iya ɗauka "Bill"
a cikin JavaScript,objectka ɗauka.nomin index。
ifi ɗauka ce tassaki, a cikin ɗanin ɗanin tassaki, JavaScript za a iya ɗauka ɗanin ɗanin ɗanin ɗanin.
a cikin ɗanin ɗanin ɗanin ɗanin ɗanin, hanyar methoduna ma ɗanin ɗanin ɗanin ɗanin ɗanin za a iya ɗauka.
实例
var person = []; person["firstName"] = "Bill"; person["lastName"] = "Gates"; person["age"] = 46; var x = person.length; // person.length za a iya ɗauka 0 var y = person[0]; // person[0] za a iya ɗauka undefined
ka ɗauka ɗauka don ɗauka ɗanin ɗanin.
object da tassaki ɗanin ɗanin ɗanin ɗanin ɗanin ɗanin ECMAScript 5 ɗanin a iya ɗauka.
object instance:
person = {firstName:"Bill", lastName:"Gates", age:62,};
tassaki instance:
points = [35, 450, 2, 7, 30, 16,];
kabara!!
Internet Explorer 8 za a iya ɗauka ɗauka.
JSON ɗanin bai ɗauka ɗauka kusa.
JSON:
person = {firstName:"Bill", lastName:"Gates", age:62};
JSON:
points = [35, 450, 2, 7, 30, 16];
Undefined ɗanin Null.
JavaScript object, ɗanin, attaki da ɗauka za a iya ɗauka.
kuma, kiyasta JavaScript object zai iya ɗauka. null
。
wannan zai iya ɗauka koyarwa da ɗanin ɗanin ɗanin ta ɗauka.
ka ɗauka ce tassaki ɗin: undefined
،لاکوورو تاهاfi ɗanin ɗanin:
实例
if (typeof myObj === "undefined")
但是您无法测试对象是否为 null
,因为如果对象未定义,将抛出错误:
不正确的:
if (myObj === null)
要解决此问题,必须测试对象是否为 null
,而不是未定义。
但这仍然会引发错误:
不正确的:
if (myObj !== null && typeof myObj !== "undefined")
因此,在测试非 null 之前,必须先测试未定义:
正确的:
if (typeof myObj !== "undefined" && myObj !== null)
期望块级范围
JavaScript 不会为每个代码块创建新的作用域。
很多编程语言都是如此,但是 JavaScript 并非如此。
认为这段代码会返回 undefined
,是新的 JavaScript 开发者的常见错误:
实例
for (var i = 0; i < 10; i++) { // 代码块 } return i;