• JavaScript 59 JavaScript 常见错误


    JavaScript

    59 JavaScript 常见错误

    一些常见的 JavaScript 错误。

    59.1 意外使用赋值运算符

    如果程序员在 if 语句中意外使用赋值运算符(=)而不是比较运算符(===),JavaScript 程序可能会产生一些无法预料的结果。

    这条 if 语句返回 false(正如预期),因为 x 不等于 10:

    var x = 0;
    if (x == 10) 
    
    • 1
    • 2

    这条 if 语句返回 true(也许不像预期),因为 10 为 true:

    var x = 0;
    if (x = 10) 
    
    • 1
    • 2

    这条 if 语句返回 false(也许不像预期),因为 0 为 false:

    var x = 0;
    if (x = 0) 
    
    • 1
    • 2

    赋值总是返回赋值的值。

    59.2 期望松散的比较

    在常规比较中,数据类型不重要。这条 if 语句返回 true

    var x = 10;
    var y = "10";
    if (x == y) 
    
    • 1
    • 2
    • 3

    在严格比较中,数据类型确实重要。这条 if 语句返回 false

    var x = 10;
    var y = "10";
    if (x === y) 
    
    • 1
    • 2
    • 3

    有一个常见的错误是忘记在 switch 语句中使用严格比较:

    这条 switch 语句会显示提示框:

    var x = 10;
    switch(x) {
        case 10: alert("Hello");
    }
    
    • 1
    • 2
    • 3
    • 4

    这条 switch 语句不会显示提示框:

    var x = 10;
    switch(x) {
        case "10": alert("Hello");
    }
    
    • 1
    • 2
    • 3
    • 4
    59.3 令人困惑的加法和级联

    加法用于加数值。

    级联(Concatenation)用于加字符串。

    在 JavaScript 中,这两种运算均使用相同的 + 运算符。

    正因如此,将数字作为数值相加,与将数字作为字符串相加,将产生不同的结果:

    var x = 10 + 5;          // x 中的结果是 15
    var x = 10 + "5";         // x 中的结果是 "105"
    
    • 1
    • 2

    如果是两个变量相加,很难预测结果:

    var x = 10;
    var y = 5;
    var z = x + y;            // z 中的结果是 15
    
    var x = 10;
    var y = "5";
    var z =  x + y;            // z 中的结果是 "105"
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    59.4 令人误解的浮点

    JavaScript 中的数字均保存为 64 位的浮点数(Floats)

    所有编程语言,包括 JavaScript,都存在处理浮点值的困难:

    var x = 0.1;
    var y = 0.2;
    var z = x + y             // z 中的结果并不是 0.3
    
    • 1
    • 2
    • 3

    在这里插入图片描述

    为了解决上面的问题,请使用乘除运算:

    var z = (x * 10 + y * 10) / 10;       // z 中的结果将是 0.3
    
    • 1
    59.5 对 JavaScript 字符串换行

    JavaScript 允许您把一条语句换行为两行:

    var x =
    "Hello World!";
    
    • 1
    • 2

    但是,在字符串中间来换行是不对的:

    var x = "Hello
    World!";
    
    • 1
    • 2

    在这里插入图片描述

    如果必须在字符串中换行,则必须使用反斜杠:

    var x = "Hello \
    World!";
    
    • 1
    • 2
    59.6 错位的分号

    因为一个错误的分号,此代码块无论 x 的值如何都会执行:

    if (x == 19);
    {
         // code block
    }
    
    • 1
    • 2
    • 3
    • 4
    59.7 对 return 语句进行换行

    在一行的结尾自动关闭语句是默认的 JavaScript 行为。

    正因如此,下面两个例子返回相同的结果:

    function myFunction(a) {
        var power = 10  
        return a * power
    }
    
    • 1
    • 2
    • 3
    • 4
    function myFunction(a) {
        var power = 10;
        return a * power;
    }
    
    • 1
    • 2
    • 3
    • 4

    JavaScript 也允许您将一条语句换行为两行。

    function myFunction(a) {
        var
        power = 10;  
        return a * power;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5

    但是,如果把 return 语句换行为两行会发生什么呢:

    function myFunction(a) {
        var
        power = 10;  
        return
        a * power;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    在这里插入图片描述

    此函数将返回 undefined

    因为 JavaScript 认为你的意思是:

    function myFunction(a) {
         var
        power = 10;  
        return;
        a * power;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    59.8 解释

    如果某条语句是不完整的:

    var
    
    • 1

    JavaScript 将通过读取下一行来完成这条语句:

    power = 10;
    
    • 1

    但是由于这条语句是完整的:

    return
    
    • 1

    JavaScript 会自动关闭该语句:

    return;
    
    • 1

    发生这种情况是因为,在 JavaScript 中,用分号来关闭(结束)语句是可选的。

    JavaScript 会在行末关闭 return 语句,因为它本身就是一条完整的语句。

    所以,绝不要对 return 语句进行换行。

    59.9 通过命名索引来访问数组

    很多编程语言支持带有命名索引的数组。

    带有命名索引的数组被称为关联数组(或散列)。

    JavaScript 不支持带有命名索引的数组。

    在 JavaScript 中,数组使用数字索引

    var person = [];
    person[0] = "Bill";
    person[1] = "Gates";
    person[2] = 46;
    var x = person.length;          // person.length 将返回 3
    var y = person[0];              // person[0] 将返回 "Bill"
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    在 JavaScript 中,对象使用命名索引。

    如果您使用命名索引,那么在访问数组时,JavaScript 会将数组重新定义为标准对象。

    在自动重定义之后,数组方法或属性将产生未定义或非正确的结果:

    var person = [];
    person["firstName"] = "Bill";
    person["lastName"] = "Gates";
    person["age"] = 46;
    var x = person.length;         // person.length 将返回 0
    var y = person[0];              // person[0] 将返回 undefined
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    59.10 用逗号来结束定义

    对象和数组定义中的尾随逗号在 ECMAScript 5 中是合法的。

    【对象】

    person = {firstName:"Bill", lastName:"Gates", age:62,}
    
    • 1

    【数组】

    points = [35, 450, 2, 7, 30, 16,];
    
    • 1

    警告!!

    Internet Explorer 8 会崩溃。

    JSON 不允许尾随逗号。

    【JSON】

    person = {firstName:"Bill", lastName:"Gates", age:62}
    
    • 1

    【JSON】

    points = [35, 450, 2, 7, 30, 16];
    
    • 1
    59.11 Undefined 不是 Null

    JavaScript 对象、变量、属性和方法可以是未定义的。

    此外,空的 JavaScript 对象的值可以为 null

    这可能会使测试对象是否为空变得有点困难。

    可以通过测试类型是否为 undefined,来测试对象是否存在:

    if (typeof myObj === "undefined")
    
    • 1

    但是无法测试对象是否为 null,因为如果对象未定义,将抛出错误:

    if (myObj === null)
    
    • 1

    要解决此问题,必须测试对象是否为 null,而不是未定义。

    但这仍然会引发错误:

    if (myObj !== null && typeof myObj !== "undefined")
    
    • 1

    因此,在测试非 null 之前,必须先测试未定义:

    【正确写法】

    if (typeof myObj !== "undefined" && myObj !== null)
    
    • 1
    59.12 期望块级范围

    JavaScript 不会为每个代码块创建新的作用域。

    很多编程语言都是如此,但是 JavaScript 并非如此。

    认为这段代码会返回 undefined,是新的 JavaScript 开发者的常见错误:

    for (var i = 0; i < 10; i++) {
      // 代码块
    }
    return i;
    
    • 1
    • 2
    • 3
    • 4

    在这里插入图片描述

  • 相关阅读:
    那些测试行业的细分岗位,你知道多少?薪资又如何?
    谈谈电子电气架构的解决方案与发展路线
    当以概念和噱头为主导的金融科技的发展模式彻底偃旗息鼓
    程序员35岁之后不写程序了,该怎样职业规划?
    嵌入式分享合集27
    使用Maven 构建、开发和打包 JavaFX 项目
    Redis篇---第四篇
    linux下定位内存泄漏 /proc/pid/status 解释
    若依 | 点击顶部 tag 标签不自动刷新
    MySql的开发环境
  • 原文地址:https://blog.csdn.net/weixin_44226181/article/details/127645115