1、Array.form

   ES6中,Array.from = function(items,mapfn,thisArg) {  }

    Array.from 用于将 类数组 和 可遍历对象(实现了Iterator接口的对象以及set、map)对象,转换成真正的数组。

   (1)   第一个参数:items,类数组 和 可遍历对象。

         在ES5中,将类数组转换成真正数组,如下:

var arr=[].slice.call(likeArray);

         实际应用中,类数组对象常常包括 NodeList集合,以及 函数参数 arguments.

  (2) 第二个参数,类似map方法,可以直接改变原数组的值。

       如下:将 类数组中的值加 1

Array.from(arrayLike, (x)=>x+);

   (3)   第三个参数,绑定this。

   (4) Array.from 可以将只要原始的数据结构(string,number 等),会先对值进行处理,

     然后转换成规范的数组结构,进而可以使用Array中的方法。 

Array.from( { length:}, ()=>'jack');

    将字符串转换为数组,能正确处理各种Unicode字符,避免 将大于 \uFFFF 的字符,算成两个字符。

function countString(string){
return Array.from(string).length;
}

2、Array.of

 Array.of = function(items) { }

  用于将一组值,转换成数组,用于弥补Array()不足。

比如:使用 Array(3),指定了数组为3,值为[undefined*3],当参数count>=2时,才会返回新数组。

  ES5中可以如下代替:

function ArrayOf(){
return [].slice.call(arguments);
}

3、扩展运算符  ( ... )

   扩展运算符背后调用的是遍历器接口(Symbol.iterator),如果A对象没有实现此接口,则无法转换。

     [...数据结构A]  这样的书写方式可以将某些数据结构转换成为数组。

   扩展运算符 无法将类数组转换为 real Array.

    

4、数组实例的扩展

    (1)copyWithin()

       Array.prototype.copyWithin = function(target,start,enf) {}

  1、在当前数组内部,将指定位置的成员复制到其他位置,且覆盖原有成员;
   2、其中 包括start,不包括enf(end from),如果[1,3,5],即将 3,4位置的元素替换 arr 
  3、start,endf为负数,则表示数组倒数位数
[, , , , , ].copyWithin(, , ); //[0,1,3,3,4,5]

   (2)find() and findIndex()

       Array.prototype.find = function(predicate,thisArg) {}

                 find()   用于找出第一个符合条件的数组成员,参数是一个回调函数,所有数组成员依次执行该回调函数,若无符合条件,则返回undefined。  

      findIndex() 则返回第一个符合条件的成员的位置,未找到,则返回 -1。

let personList = [
{
name: 'jack',
age:
},
{
name: 'Tom',
age:
},
{
name: 'Lily',
age:
}
]; personList.find((item,index,arr)
=>(item.age < ));

  这两个方法都可以发现 NaN,弥补了数组 IndexOf方法的不足。

[NaN].findIndex(y=>Object.is(NaN,y)) //

    (3) fill()

    Array.prototype.fill = function(value,start,end) {}
   使用给定值,填充一个数组。
['a','b','c'].fill(,,);//[a,7,c]

    (4)entries(),keys(),values()

    var arr = ['key1', 'key2'];
for (let index of arr.keys) { }

        如果不使用for...of循环,可以手动调用遍历器对象的next方法,进行遍历。

    (5)includes()   

        String.prototype.includes = function(searchString,position) {};

        表示某个数组是否包含给定的值

            position 表示搜索的起始位置,负数为倒数位置

     indexOf 内部使用严格相当运算符(===)进行判断,这会导致对NaN的误判。

    [, , ].includes(, );
[NaN].indexOf(NaN); //-1
[NaN].includes(NaN); //true
    Map 的has方法,用来查找 键名。  
   Set 的has方法,用来查找 值。

(5)数组的空位

   数组的空位,是指某一个位置没有任何值,空位不是undefined。

   1、forEach,filter,every,some 都会跳过空位。

   2、map会跳过空位,但会保留这个值。

   3、join 、toString 会将空位视为 undefined,undefined和null 则被处理成空字符串。

  而Array.from 会将数组的空位 转换为 undefined,不会忽略这个空位。
( ... )也会转换为 undefined。 至于为什么会出现 空位,我也不太明白。
  

ES6(三)数组的扩展的更多相关文章

  1. ES6对数组的扩展(简要总结)

    文章目录 数组的扩展(ES6) 1. 扩展运算符 2. Array.from 3. Array.of() 4. copyWithin() 5. find() 和 findIndex() 6. fill ...

  2. ES6 之 数组的扩展

    ES5 检测数组 let arr = [1,2,3,4] Array.isArray(arr) arr instanceof Array 转换方法 arr.toLocaleString() arr.t ...

  3. ES6对数组的扩展

    ECMAScript6对数组进行了扩展,为数组Array构造函数添加了from().of()等静态方法,也为数组实例添加了find().findIndex()等方法.下面一起来看一下这些方法的用法. ...

  4. 【ES6】数组的扩展——扩展运算符

    1.扩展运算符[三个点(...)将一个数组转为用逗号分隔的参数序列] 作用:用于函数调用 function add(x, y) { return x + y; } const numbers = [2 ...

  5. 【ES6】数组的扩展

    1.Array.from(): 将伪数组对象和遍历的对象转为真数组 如果一个对象的键都是正整数或者0,并且有 Length属性,那么这个对象很想数组,称它为伪数组. 伪数组: let obj = { ...

  6. ES6学习(三):数组的扩展

    chapter08 数组的扩展 8.1 扩展运算符 8.1.1 扩展运算符的含义 ... 如同rest运算符的逆运算,将一个数组转换为用逗号分隔的参数序列. console.log(...[1, 2, ...

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

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

  8. es6数组的扩展

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

  9. ES6的新特性(8)——数组的扩展

    数组的扩展 扩展运算符 含义 扩展运算符(spread)是三个点(...).它好比 rest 参数的逆运算,将一个数组转为用逗号分隔的参数序列. console.log(...[1, 2, 3]) / ...

  10. ES6中数组和对象的扩展运算符拷贝问题以及常用的深浅拷贝方法

    在ES6中新增了扩展运算符可以对数组和对象进行操作.有时候会遇到数组和对象的拷贝,可能会用到扩展运算符.那么这个扩展运算符到底是深拷贝还是浅拷贝呢? 一..使用扩展运算符拷贝 首先是下面的代码. le ...

随机推荐

  1. php结合redis实现高并发下的抢购、秒杀功能 (转载)

    抢购.秒杀是如今很常见的一个应用场景,主要需要解决的问题有两个: 1 高并发对数据库产生的压力 2 竞争状态下如何解决库存的正确减少("超卖"问题) 对于第一个问题,已经很容易想到 ...

  2. Git基本使用命令(windows)

    1.  记住一个名词repository版本库 =======================基本操作======================== git init 在需要的地方建立一个版本库(也 ...

  3. Android异步消息机制

    Android中的异步消息机制分为四个部分:Message.Handler.MessageQueue和Looper. 其中,Message是线程之间传递的消息,其what.arg1.arg2字段可以携 ...

  4. Linux Rsync备份服务介绍及部署守护进程模式

    rsync介绍 rsync是一款开源的.快速的.多功能的.可实现全量及增量的本地或远程数据同步备份工具 在常驻模式(daemon mode)下,rsync默认监听TCP端口873,以原生rsync传输 ...

  5. 深入浅出了解OCR识别票据原理

    欢迎大家前往云加社区,获取更多腾讯海量技术实践干货哦~ 译者:Mr.Geek 本文翻译自dzone 中Ivan Ozhiganov所发文章Deep Dive Into OCR for Receipt ...

  6. 剑指Offer_4_二维数组中的查找

    题目描述       在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数.       ...

  7. hdu1181 变形课(vector容器+dfs)

    变形课 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/65536 K (Java/Others) Total Submi ...

  8. HDU 1013.Digital Roots【模拟或数论】【8月16】

    Digital Roots Problem Description The digital root of a positive integer is found by summing the dig ...

  9. hdu 4883 区间选点

    昨天比赛的时候没有做出来,本来是想用贪心的,可是贪了好久都没有招, 今天在网上搜了解题报告~好像说这是一类区间选点问题: 有一个好的做法: (1)首先把题目中的时间全转化为分钟,那么区间就在0-144 ...

  10. MyBatis_关联关系查询

    一.关联查询 当查询的内容涉及到具有关联关系的多个表时,就需要使用关联查询.根据表与表间的关联关系的不同.关联查询分为四种: 一对一关联查询: 一对多关联查询: 多对一关联查询: 多对多关联查询: 二 ...