• JavaScript 62 JavaScript 版本 62.2 JavaScript ES5


    JavaScript

    62 JavaScript 版本

    62.2 JavaScript ES5
    62.2.1 ECMAScript 5 是什么?

    ECMAScript 5 也称为 ES5 和 ECMAScript 2009。

    62.2.2 ECMAScript 5 特性

    2009 年发布的新特性:

    • “use strict” 指令
    • String.trim()
    • Array.isArray()
    • Array.forEach()
    • Array.map()
    • Array.filter()
    • Array.reduce()
    • Array.reduceRight()
    • Array.every()
    • Array.some()
    • Array.indexOf()
    • Array.lastIndexOf()
    • JSON.parse()
    • JSON.stringify()
    • Date.now()
    • 属性 Getter 和 Setter
    • 新的对象属性和方法
    62.2.3 ECMAScript 5 语法更改
    • 对字符串的属性访问 [ ]
    • 数组和对象字面量中的尾随逗号
    • 多行字符串字面量
    • 作为属性名称的保留字
    62.2.4 “use strict” 指令

    use strict” 定义 JavaScript 代码应该以“严格模式”执行。

    例如,使用严格模式,不能使用未声明的变量。

    您可以在所有程序中使用严格模式。它可以帮助您编写更清晰的代码,例如阻止您使用未声明的变量。

    use strict” 只是一个字符串表达式。旧浏览器如果不理解它们就不会抛出错误。

    62.2.5 String.trim()

    String.trim() 删除字符串两端的空白字符。

    var str = "       Hello World!        ";
    alert(str.trim());
    
    • 1
    • 2

    在这里插入图片描述

    62.2.6 Array.isArray()

    isArray() 方法检查对象是否为数组。

    function myFunction() {
      var fruits = ["Banana", "Orange", "Apple", "Mango"];
      var x = document.getElementById("demo");
      x.innerHTML = Array.isArray(fruits);
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5

    在这里插入图片描述

    62.2.7 Array.forEach()

    forEach() 方法为每个数组元素调用一次函数。

    var txt = "";
    var numbers = [45, 4, 9, 16, 25];
    numbers.forEach(myFunction);
    
    function myFunction(value) {
      txt = txt + value + "
    "; }
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    62.2.8 Array.map()

    这个例子给每个数组值乘以 2:

    var numbers1 = [45, 4, 9, 16, 25];
    var numbers2 = numbers1.map(myFunction);
    
    function myFunction(value) {
      return value * 2;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    62.2.9 Array.filter()

    此例用值大于 18 的元素创建一个新数组:【过滤】

    var numbers = [45, 4, 9, 16, 25];
    var over18 = numbers.filter(myFunction);
    
    function myFunction(value) {
      return value > 18;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    62.2.10 Array.reduce()

    这个例子确定数组中所有数的总和:【迭代方法】

    var numbers1 = [45, 4, 9, 16, 25];
    var sum = numbers1.reduce(myFunction);
    
    function myFunction(total, value) {
      return total + value;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    62.2.11 Array.reduceRight()

    这个例子同样是确定数组中所有数的总和:

    var numbers1 = [45, 4, 9, 16, 25];
    var sum = numbers1.reduceRight(myFunction);
    
    function myFunction(total, value) {
      return total + value;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    62.2.12 Array.every()

    这个例子检查是否所有值都超过 18:

    var numbers = [45, 4, 9, 16, 25];
    var allOver18 = numbers.every(myFunction);
    
    function myFunction(value) {
      return value > 18;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    【这些其实在之前已经看过了】

    62.2.13 Array.some()

    这个例子检查某些值是否超过 18:

    var numbers = [45, 4, 9, 16, 25];
    var allOver18 = numbers.some(myFunction);
    
    function myFunction(value) {
      return value > 18;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    62.2.14 Array.indexOf()

    检索数组中的某个元素值并返回其位置:

    var fruits = ["Banana", "Orange", "Apple", "Mango"];
    var a = fruits.indexOf("Apple");
    
    • 1
    • 2
    62.2.15 Array.lastIndexOf()

    Array.lastIndexOf()Array.indexOf() 类似,但是从数组结尾处开始检索。

    var fruits = ["Banana", "Orange", "Apple", "Mango"];
    var a = fruits.lastIndexOf("Apple");
    
    • 1
    • 2
    62.2.16 JSON.parse()

    JSON 的一个常见用途是从 Web 服务器接收数据。

    JavaScript 函数 JSON.parse() 用于将文本转换为 JavaScript 对象:

    var obj = JSON.parse('{"name":"Bill", "age":62, "city":"Seatle"}');
    
    • 1
    62.2.17 JSON.stringify()

    JSON 的一个常见用途是将数据发送到Web服务器。

    将数据发送到 Web 服务器时,数据必须是字符串。

    var obj = {"name":"Bill", "age":62, "city":"Seatle"};
    
    • 1

    使用 JavaScript 函数 JSON.stringify() 将其转换为字符串。

    var myJSON = JSON.stringify(obj);
    
    • 1

    结果将是遵循 JSON 表示法的字符串。

    myJSON 现在是一个字符串,准备好发送到服务器:

    var obj = {"name":"Bill", "age":62, "city":"Seatle"};
    var myJSON = JSON.stringify(obj);
    document.getElementById("demo").innerHTML = myJSON;
    
    • 1
    • 2
    • 3
    62.2.18 Date.now()

    Date.now() 返回自零日期(1970 年 1 月 1 日 00:00:00:00)以来的毫秒数

    var timInMSs = Date.now();
    
    • 1

    Date.now() 的返回与在 Date 对象上执行 getTime() 的结果相同。

    62.2.19 属性 Getter 和 Setter

    ES5 允许您使用类似于获取或设置属性的语法来定义对象方法。

    这个例子为名为 fullName 的属性创建一个 getter

    // 创建对象:
    var person = {
      firstName: "Bill",
      lastName : "Gates",
      get fullName() {
        return this.firstName + " " + this.lastName;
      }
    };
    
    // 使用 getter 显示来自对象的数据:
    document.getElementById("demo").innerHTML = person.fullName;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    这个例子为语言属性创建一个 setter 和一个 getter

    var person = {
      firstName: "Bill",
      lastName : "Gates",
      language : "NO",
      get lang() {
        return this.language;
      },
      set lang(value) {
        this.language = value;
      }
    };
    
    // 使用 setter 设置对象属性:
    person.lang = "en";
    
    // 使用 getter 显示来自对象的数据:
    document.getElementById("demo").innerHTML = person.lang;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17

    这个例子使用 setter 来确保语言的大写更新:

    var person = {
      firstName: "Bill",
      lastName : "Gates",
      language : "NO",
      set lang(value) {
        this.language = value.toUpperCase();
      }
    };
    
    // 使用 setter 设置对象属性:
    person.lang = "en";
    
    // 显示来自对象的数据:
    document.getElementById("demo").innerHTML = person.language;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    62.2.20 新的对象属性和方法

    Object.defineProperty() 是 ES5 中的新对象方法。

    它允许定义对象属性和/或更改属性的值和/或元数据。

    // 创建对象:
    var person = {
      firstName: "Bill",
      lastName : "Gates",
      language : "NO", 
    };
    
    // 更改属性:
    Object.defineProperty(person, "language", {
      value: "EN",
      writable : true,
      enumerable : true,
      configurable : true
    });
    
    // 枚举属性
    var txt = "";
    for (var x in person) {
      txt += person[x] + "
    "; } document.getElementById("demo").innerHTML = txt;
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21

    下一个例子是相同的代码,但它隐藏了枚举中的语言属性:

    // 创建对象:
    var person = {
      firstName: "Bill",
      lastName : "Gates",
      language : "NO", 
    };
    
    // 更改属性:
    Object.defineProperty(person, "language", {
      value: "EN",
      writable : true,
      enumerable : false,
      configurable : true
    });
    
    // 枚举属性
    var txt = "";
    for (var x in person) {
      txt += person[x] + "
    "; } document.getElementById("demo").innerHTML = txt;
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21

    此例创建一个 setter 和 getter 来确保语言的大写更新:

    // 创建对象:
    var person = {
      firstName: "Bill",
      lastName : "Gates",
      language : "NO"
    };
    
    // 更改属性:
    Object.defineProperty(person, "language", {
      get : function() { return language },
      set : function(value) { language = value.toUpperCase()}
    });
    
    // 更改语言
    person.language = "en";
    
    // 显示语言
    document.getElementById("demo").innerHTML = person.language;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    62.2.21 ES5 新的对象方法

    ECMAScript 5 为 JavaScript 添加了许多新的对象方法:

    // 添加或更改对象属性
    Object.defineProperty(object, property, descriptor)
    
    // 添加或更改多个对象属性
    Object.defineProperties(object, descriptors)
    
    // 访问属性
    Object.getOwnPropertyDescriptor(object, property)
    
    // 将所有属性作为数组返回
    Object.getOwnPropertyNames(object)
    
    // 将可枚举属性作为数组返回
    Object.keys(object)
    
    // 访问原型
    Object.getPrototypeOf(object)
    
    // 防止向对象添加属性
    Object.preventExtensions(object)
    
    // 如果可以将属性添加到对象,则返回 true
    Object.isExtensible(object)
    
    // 防止更改对象属性(而不是值)
    Object.seal(object)
    
    // 如果对象被密封,则返回 true
    Object.isSealed(object)
    
    // 防止对对象进行任何更改
    Object.freeze(object)
    
    // 如果对象被冻结,则返回 true
    Object.isFrozen(object)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    62.2.22 对字符串的属性访问

    charAt() 方法返回字符串中指定索引(位置)的字符:

    var str = "HELLO WORLD";
    str.charAt(0);            // 返回 H
    
    • 1
    • 2

    ECMAScript 5 允许对字符串进行属性访问:

    var str = "HELLO WORLD";
    str[0];                   // 返回 H
    
    • 1
    • 2

    对字符串的属性访问可能有点不可预测。

    62.2.23 尾随逗号(Trailing Commas)

    ECMAScript 5 允许在对象和数组定义中使用尾随逗号:

    【Object 实例】

    person = {
      firstName: "Bill",
      lastName: " Gates",
      age: 62,
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5

    【Array 实例】

    points = [
      1,
      5,
      10,
      25,
      40,
      100,
    ];
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    警告!!!

    Internet Explorer 8 将崩溃。

    JSON 不允许使用尾随逗号。

    【JSON 对象:】

    // 允许:
    var person = '{"firstName":"Bill", "lastName":"Gates", "age":62}'
    JSON.parse(person)
    
    // 不允许:
    var person = '{"firstName":"Bill", "lastName":"Gates", "age":62,}'
    JSON.parse(person)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    【JSON 数组:】

    // 允许:
    points = [40, 100, 1, 5, 25, 10]
    
    // 不允许:
    points = [40, 100, 1, 5, 25, 10,]
    
    • 1
    • 2
    • 3
    • 4
    • 5
    62.2.24 多行字符串

    如果使用反斜杠转义,ECMAScript 5 允许多行的字符串文字(字面量):

    "Hello \
    Kitty!";
    
    • 1
    • 2

    \ 方法可能没有得到普遍的支持。

    较旧的浏览器可能会以不同的方式处理反斜杠周围的空格。

    一些旧的浏览器不允许 \ 字符后面的空格。

    分解字符串文字的一种更安全的方法是使用字符串添加:

    "Hello " + 
    "Kitty!";
    
    • 1
    • 2
    62.2.25 保留字作为属性名称

    ECMAScript 5 允许保留字作为属性名称:

    【对象实例】

    var obj = {name: "Bill", new: "yes"}
    
    • 1
    62.2.26 ES5(ECMAScript 5)浏览器支持

    Chrome 23、IE 10 和 Safari 6 是第一批完全支持 ECMAScript 5 的浏览器:

    在这里插入图片描述

  • 相关阅读:
    AIGC ChatGPT 4 与 Python 进行数据分析与可视化
    基于球向量的粒子群优化(SPSO)算法在无人机路径规划中的实现(Matlab代码实现)
    财务分析就是财务报表分析吗?
    小程序setData动态传递key
    svg图标转组件引入项目中
    Redis内存不足解决方案
    理解C++四种强制类型转换static_cast、const_cast、reinterpret_cast和dynamic_cast
    HTTP 请求
    升级鸿蒙4.2新变化,新增 WLAN 网络自动连接开关!
    Flutter笔记:目录与文件存储以及在Flutter中的使用(下)
  • 原文地址:https://blog.csdn.net/weixin_44226181/article/details/127645209