ES6对数组引入了几个新函数:

(1) Array.of()

  作用是将一组数值,转换为数组。

  Array.of(1,2,3,4);  //[1,2,3,4]

(2) Array.from()

  作用是把类数组的对象或者可遍历的对象变为真正数组,并返回此数组。

  let ele=document.getElementsByTagName('a');

  ele instanceof Array;   //false

  ele instanceof Object;   //true

我们使用Array.from()可以把对象转为数组:

  Array.from(ele) instanceof Array    //true

字符串处理:

  let str='hello';

  Array.from(str);    //['h','e','l','l','o']

(3) find() 函数

  作用是在数组中找到符合条件的第一个元素。其参数为一个匿名函数。

  let arr=[1,2,3,4,5,3];

  arr.find(function( value ){

    return value>2;    //3

   // return value>6;    //当没有找到符合条件的元素时返回 undefined;

  })  ;

(4) findIndex() 函数

  作用是返回符合条件的第一个元素在数组中的下标。

  let arr=[7,8,9,10];

  arr.findIndex(function( value ){

    return value>8;      //2  ,没有找到时返回-1

  })

  可以看到 findIndex()和find()的函数的用法相同,作用也基本相同,只是一个返回元素值,一个返回元素的下标。

(5) fill() 函数

  作用用指定的值填充数组。

  let arr=[1,2,3];

  arr.fill(4);   //arr=[4,4,4]  默认为全部填充;

  arr.fill(4,1,3);   //arr=[1,4,4]  第一个参数为要填充的元素,后两个参数表示填充范围的下标为 >=1 && <3 ,即下标为1,2的位置。当最后一个参数超出数组时,则填充到结尾。

(6) entries() 函数

  作用对函数的键值进行遍历,返回一个遍历器(即遍历结果),可以用for...of对其遍历。

  for(let [i,v] of ['a','b'].entries()){

    console.log(i,v);

  }

   得到数组的键值为:0,1 ,相应的值为: 'a'和'b'。

(7) keys() 函数

   作用对数组的索引键进行遍历,返回一个遍历器。

   for (let index of ['a','b'].keys()){

    console.log(index)

  }

   

(8) values() 函数

  作用只对数组的元素进行遍历,返回一个遍历器。

  for (let value of ['a','b'].values()){

    console.log(value);

  }

  //a

  //b

(9) 数组推导:用简洁的写法,直接通过现有的数组生成新的数组。

  传统的写法:

  var arr1=[1,2,3];

  var arr2=[];

  for (let i=0;i<arr1.length;i++){

    arr2.push(arr1[i]*2);

  }

  或者可以使用forEach:

  arr1.forEach(function(i){

     arr2.push(i*2);

  });

  新写法:(但是测试发现,chrome还不支持这种写法,Firefox支持。

  var arr1=[1,2,3];

  var arr2=[for(i of arr1)i*2];  //2,4,6

  还可以加上if判断:

  var arr3=[for(i of arr2) if(i>3) i];  //4,6

  

___________________________

参考公众号:web前端教程

  

ES6 — 数组Array的更多相关文章

  1. es6 --数组--Array.from() 、Array.isArray()、Array.of()、find()、findIndex()、fill()、entries() 、keys() ,values()

    将两类对象转为真正的数组 Array.from()方法用于将两类对象转为真正的数组:类似数组的对象(array-like object)和可遍历(iterable)的对象(包括ES6新增的数据结构Se ...

  2. ES6数组的扩展--Array.from()和Array.of()

    一. Array.from() : 将伪数组对象或可遍历对象转换为真数组 1.何为伪数组 如果一个对象的所有键名都是正整数或零,并且有length属性,那么这个对象就很像数组,语法上称为"类 ...

  3. ES6之Array数组

    定义数组 ,]; const arr = new Array(1,2,3,4); const array1 = new Array(); array1[]="test"; 给数组不 ...

  4. ES6数组扩展

    前面的话 数组是一种基础的JS对象,随着时间推进,JS中的其他部分一直在演进,而直到ES5标准才为数组对象引入一些新方法来简化使用.ES6标准继续改进数组,添加了很多新功能.本文将详细介绍ES6数组扩 ...

  5. ES6数组及数组方法

    ES6数组可以支持下面的几种写法: (1)var [a,b,c] = [1,2,3]; (2)var [a,[[b],c]] = [1,[[2],3]]; (3)let [x,,y] = [1,2,3 ...

  6. 数组的复制及ES6数组的扩展

    一.数组的复制 // alert([1,2,3]==[1,2,3]); let cc = [0,1,2]; let dd = cc; alert(dd==cc);//此时改变dd会影响cc ES5 只 ...

  7. ES6,Array.fill()函数的用法

    ES6为Array增加了fill()函数,使用制定的元素填充数组,其实就是用默认内容初始化数组. 该函数有三个参数. arr.fill(value, start, end) value:填充值. st ...

  8. es6数组的扩展

    数组扩展运算符 ...(三个点) const demoArr=[0,1,2,3,4] console.log(...demoArr) // 0 1 2 3 4 // 他把一个数组用逗号分隔了出来 // ...

  9. es6数组

    将两类对象转为真正的数组 Array.from方法用于将两类对象转为真正的数组:类似数组的对象(array-like object)和可遍历(iterable)的对象(包括ES6新增的数据结构Set和 ...

随机推荐

  1. centos下cmake安装

    步骤一.安装gcc等必备程序包(已安装则略过此步,用gcc -v检测) yum install -y gcc gcc-c++ make automake 步骤二.安装wget (已安装则略过此步) y ...

  2. Winform在一个窗体获取其他窗体的值

    比如:Form2获取Form1 的label的值 因为默认的窗体的所有控件属性和方法都是private, Form1 form1 = new Form1(); 这样也是获取不到的 方法一.最简单的 将 ...

  3. visual studio 2013连接Oracle 11g并获取数据:(二:实现)

    1.VS中新建一个winform窗体 (1)一个按钮 (2)一个数据表格视图(在里面显示得到的数据表) 2.双击按钮进入代码 (1)添加 using System.Data.OracleClient; ...

  4. 内工大acm校赛--整理代码

    题目:小明搜到一行无缩进无换行代码,请帮小明整理代码.无for语句和case语句,而且只有一个主函数.你只要控制注意“:”“{”“}”这三个符号带来的缩进和换行效果就行. Input: 输入只有一行, ...

  5. JAVA异常体系

    1.异常体系 ----|Throwable 所有错误或异常的父类 --------|Error(错误) --------|Exception(异常)一般能通过代码处理 ------------|运行时 ...

  6. ios上传应用后,审核流程完成前(reveiw)修改了程序内容,如何上传替换

    其实挺简单,只需要更改下version和build版本 看图说话就可以.我的程序之前版的版本设置 修改bug之后的设置: 然后重新打包就好了,提示打包成功后,在itunesconnect查看发现 选中 ...

  7. hdu2196 树的直径 + bfs

    //Accepted 740 KB 15 ms //树的直径 //距离一个顶点最远的点一定是树的直径的一个端点 #include <cstdio> #include <cstring ...

  8. HDU 3336 - Count the string(KMP+递推)

    题意:给一个字符串,问该字符串的所有前缀与该字符串的匹配数目总和是多少. 此题要用KMP的next和DP来做. next[i]的含义是当第i个字符失配时,匹配指针应该回溯到的字符位置. 下标从0开始. ...

  9. HDU 3333 - Turing Tree (树状数组+离线处理+哈希+贪心)

    题意:给一个数组,每次查询输出区间内不重复数字的和. 这是3xian教主的题. 用前缀和的思想可以轻易求得区间的和,但是对于重复数字这点很难处理.在线很难下手,考虑离线处理. 将所有查询区间从右端点由 ...

  10. html<textarea>标签

    最近在项目中页面回显<textarea>的值,可是设置了value属性怎么也回显不出来,后来才弄清楚,原来想要设置<textarea>的文本,不是使用value,而是如下方式: ...