zoukankan      html  css  js  c++  java
  • ES6躬行记(12)——数组

      ES6为数组添加了多个新方法,既对它的功能进行了强化,也消除了容易产生歧义的语法。

    一、静态方法

    1)of()

      ES6为Array对象新增的第一个静态方法是of(),用于创建数组,它能接收任意个参数,返回值是由这些参数组成的新数组。创建数组比较传统的做法是用构造函数Array(),但当参数是一个正整数时,得到的却是一个带指定长度的空数组,而不是包含该参数的数组。Array.of()就不存在这种会产生歧义的行为,它不受参数的数据类型和数量的影响,返回的都是相同的结果,两种创建方式的对比如下所示。

    Array.of(2);        //[2]
    Array(2);       //[ , ]

    2)from()

      第二个新增的静态方法是from(),可将类数组对象和可迭代对象转换成数组,它接收3个参数,第一个是待转换的对象,第二和第三都是可选参数,前者是回调函数,后者是执行回调函数时所绑定的this对象。在下面的代码中,obj是一个类数组对象,分别用两种方式对其进行类型转换,可以看出,Array.from()与传统方式相比,可读性与简洁性更胜一筹。

    var obj = {0: 1, 1: 2, 2: 3, length: 3};
    [].slice.call(obj);        //传统转换方式
    Array.from(obj);       //新的转换方式

      利用回调函数可以完成更加复杂的映射转换(例如让每个元素翻倍,如下代码所示),它的第一个参数是当前元素,第二个参数是元素索引。

    Array.from(obj, function(value, index) {
      return value * 2;
    });

    二、原型方法

      很多第三方类库(例如underscore.js、lodash.js等)都会提供数组相关的辅助函数,而ES6将其中的几个函数纳入到了标准中,大大降低了数组的使用难度,新增的原型方法如表6所示。

    表6  新的原型方法

    方法 功能描述
    fill() 将固定值填充到数组指定的范围内
    copyWithin() 将数组的元素复制到同一数组的其它位置
    find() 查找第一个满足条件的匹配元素
    findIndex() 查找第一个满足条件的匹配元素的索引
    keys() 遍历数组的索引(键)
    values() 遍历数组的元素(值)
    entries() 遍历数组的索引和元素(键/值对)

    1)fill()和copyWithin()

      fill()和copyWithin()两个方法都能接收3个参数(如表7所示),表中的复制序列是指需要复制的元素序列,而位置就是数组的索引。

    表7  三个参数说明

    方法 第一个参数 第二个参数(可选) 第三个参数(可选)
    fill() value:需要填充的值 start:开始填充的位置 end:结束填充的位置
    copyWithin() target:开始执行复制的位置 start:复制序列的起始位置 end:复制序列的结束位置

      在使用这两个方法时,有五个点需要注意,如下所列:

    (1)不仅会修改原始数组,还会覆盖指定范围内的元素。

    (2)复制或填充执行的都是浅拷贝。

    (3)当方法中的索引参数为负数时,会先和数组的长度相加,再计算出最终的索引。

    (4)保持数组的长度不变,在数组末尾停止复制或填充。

    (5)end参数的默认值为数组长度,并且该位置上的元素会被忽略。

      在了解过它们使用时的注意事项后,再来理解下面的代码就会相对简单很多。

    var arr1 = [1, 2, 3, 4, 5];
    arr1.fill(6, 0, 2);           //[6, 6, 3, 4, 5]
    arr1.fill(7, 2, -1);          //[6, 6, 7, 7, 5]
    var arr2 = [1, 2, 3, 4, 5];
    arr2.copyWithin(2, 0, 2);       //[1, 2, 1, 2, 5]
    arr2.copyWithin(2, 0, -2);      //[1, 2, 1, 2, 1]

    2)find()和findIndex()

      find()和findIndex()是对indexOf()的一种补充,indexOf()只能通过全等匹配(===)来搜索指定的值,而这两个新方法却可以自定义匹配条件。在下面的代码中,通过indexOf()方法只能检索出数字1的位置,改成字符串“1”后就无法匹配成功。

    var arr = [1, 2, 3, 4, 5];
    arr.indexOf(1);                //0
    arr.indexOf("1");               //-1

      find()和findIndex()都能接收2个参数,第一个是回调函数,第二个是可选的参数,表示执行回调函数时所绑定的this对象,其中回调函数包含3个参数:当前元素、元素索引和原始数组。当匹配失败时,find()返回undefined,而findIndex()返回-1。下面用这两个新方法搜索字符串“1”,可分别获得匹配元素和其所在的索引。

    arr.find(function(value, index, array) {         //1
      return value == "1";
    });
    arr.findIndex(function(value, index, array) {    //0
      return value == "1";
    });

      keys()、values()和entries()是三个迭代器方法,都返回一个可迭代的对象,为了能更直观的演示它们各自的功能,现在利用扩展运算符将返回值转换成数组,如下所示。

    var arr = ["a", "b", "c"];
    [...arr.keys()];           //[0, 1, 2]
    [...arr.values()];         //["a", "b", "c"]
    [...arr.entries()];        //[[0, "a"], [1, "b"], [2, "c"]]
  • 相关阅读:
    初识Activity
    贝叶斯公式由浅入深大讲解—AI基础算法入门【转】
    jz2440使用openjtag+openocd+eclipse调试【学习笔记】
    win10下搭建jz2440v3(arm s3c2440)开发及gdb调试环境【转】
    Eclipse安装zylin[转]
    Ubuntu 16.04下EasyOpenJTAG+OpenOCD的安装和使用【转】
    如何退出minicom【学习笔记】
    Python Matplotlib简易教程【转】
    anacoda的spyder在调用matplotlib的时候无法显示动画效果【学习笔记】
    Spyder如何在弹出框绘图【转】
  • 原文地址:https://www.cnblogs.com/strick/p/10225274.html
Copyright © 2011-2022 走看看