chapter08 数组的扩展

8.1 扩展运算符

8.1.1 扩展运算符的含义

...

如同rest运算符的逆运算,将一个数组转换为用逗号分隔的参数序列。

    console.log(...[1, 2, 3])  // 1, 2, 3
// 用于函数调用
function add (x, y) {
return x + y;
} add(...[1, 2]); // 3

8.1.2 代替数组的apply方法

apply方法可以将数组转为函数的参数

    // ES5的写法
function f (x, y ,z) {
// todo
}
let args = [1, 2, 3];
f.apply(null, args);
// ES6的写法
function f (x, y ,z) {
// todo
}
let args = [1, 2, 3];
f(...args);

8.1.3 扩展运算符的应用

  • 合并数组

    // ES5
    [1, 2].concat(more);
    // ES6
    [1, 2, ...more]
  • 与解构赋值相结合

    // ES5
    a = list[0]
    rest = list.slice(1);
    // ES6
    [a, ...rest] = list; const [first, ...rest] = [1, 2, 3, 4, 5];
    first // 1
    rest // [2, 3, 4 ,5]

    注意:如果扩展运算符用于解构赋值,只能将其放置在参数的最后一位

  • 处理函数的返回值

    函数返回了一个可枚举的数据类型,则可以对其使用扩展运算符处理。

  • 字符串

    [...'hello'] // ['h', 'e', 'l', 'l', 'o']

    这种写法的好处是可以正确识别32位的Unicode

    function length (str) {
    return ...str.length;
    }

    以上函数可以正确返回字符串的长度

  • Iterator接口

    扩展运算符可以作用在任何实现了Iterator接口的数据类型上(Map, Set, Generator等)。

8.2 Array.from()

Array.from()用于将两类对象转换为真正的数组:类似数组的对象和可遍历的对象(包括ES6新增的Set和Map)。

    let arrayLike = {
'0': 'a',
'1': 'b',
'2': 'c',
length: 3
}; // ES5的写法
let arr1 = [].slice.call(arrayLike); // ['a', 'b', 'c'] // ES6的写法
let arr2 = Array.from(arrayLike);

常见的类数组对象:DOM操作返回的NodeList对象和arguments对象。

所谓类数组,本质特征只有一点:必须具有length属性。任何有有length属性的对象,都可以通过Array.from方法转为数组。

...扩展运算符也可以将某些数据结构转换成数组,但是其原理是通过Iterator接口转换。

    Array.from({ length: 2});
// [undefined, undefined]

Array.from()还可以接受第二个参数,作用类似于数组的map方法,用于对每一个数组元素进行处理,并且将处理后的值放入返回的数组。

如果map函数里面用到了this,还可以指定第三个参数用来绑定this。

    Array.from({ length: 2 }, () => 'jack');
// ['jack', 'jack'] function countSymbol (string) {
return Array.from(string).length;
}

8.3 Array.of()

将一组值转换为一个数组,主要是用来解决Array构造函数的怪异。

8.4 数组实例.copyWithin()

在数组内部进行复制,参数(target, start, end)

  • target (可选)开始进行复制的下标
  • start (可选)开始被复制的下标
  • end (可选)要被复制的范围,不包括

8.5 Array.find() & Array.findIndex()

作用就和名称一致。

参数:

  • fn (value, index, arr) {}

    筛选函数,最多接受三个参数

  • this

    筛选函数的this对象

8.6 Array.fill()

填充数组

扩展版本:Array.fill(str2Fill, start, end)

指定填充的区间 [ start, end )

8.7 数组实例的enties() keys() values()

分别返回三种迭代器,可以使用 for/of 或者 next() 方法进行迭代。

8.8 数组实例的includes() 方法

见名知义

includes()和find()方法可以找到NaN

8.9 数组的空位

ES6将空位视为undefined

空位处理的规则并不统一,所以建议尽量不要出现空位。

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

  1. ES6 学习6 数组的扩展

    本章学习要点: 扩展运算符 Array.from() Array.of() 数组实例的 copyWithin() 数组实例的 find() 和 findIndex() 数组实例的 fill() 数组实 ...

  2. ES6中对数组的扩展

    hello,大家好,我又来了.         前面讲了字符串和数值的扩展,今天要讲的是:数组的扩展.不知道大家能否跟得上这个节奏,你们在阅读中对讲解有存在疑惑,记得留言提出来,要真正地理解,否则白白 ...

  3. js-ES6学习笔记-数组的扩展

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

  4. ES6-11学习笔记--数组的扩展

    类数组 / 伪数组 Array.from() Array.of() copyWithin() fill() includes()   类数组.伪数组例子: let divs = document.ge ...

  5. ES6学习之数组扩展

    扩展运算符(...将数组分割为用逗号分割的参数序列) console.log(...[1,2,3]) //1 2 3 可替换数组的apply写法: function test(x,y,z){ cons ...

  6. ES6中的数组方法扩展

    上一篇文章小编简单介绍了在ES6中,一些常用的方法和一些简单的应用,在这篇文章中,小编将针对ES6中数组常用方法进行扩展,相信经过这篇文章之后,每一位小伙伴下班时间会有所提前,就算从原来的996变成9 ...

  7. JavaScript学习笔记 -- ES6学习(三) 变量的解构赋值

    1.解构赋值的定义 在ES6中,允许按照一定模式,从数组和对象中提取值(所谓解构),然后对变量进行赋值. var a = 1; var b = 2; var c = 3; //等价于 var [a, ...

  8. ES6学习笔记(二)——字符串扩展

    相信很多人也和我一样,不喜欢这样循规蹈矩的逐条去学习语法,很枯燥乏味.主要是这样学完一遍之后,没过一段时间就忘到九霄云外了.不如实际用到的时候研究它记得牢靠,所以我就整理成笔记,加深记忆的同时便于复习 ...

  9. ES6学习历程(字符串的扩展)

    字符串的扩展 在看这一节的时候前半部分写的都是关于unicode的内容,我个人感觉这部分在实际的开发中用的很少,所以不打算在做记录,等届时用到再有针对性的看,所以就将在ES6里面关于字符串操作的一些新 ...

  10. JavaScript学习笔记--ES6学习(四) 字符串的扩展

    ES6对字符串进行了一些扩展,主要表现在对Unicode 大于\uFFFF的字符的处理上. 1. ES6中字符的Unicode表示方法 在ES5中,字符串的Unicode表示方法: \uxxxx . ...

随机推荐

  1. LeetCode 122.买卖股票的最佳时机(C++)

    给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格. 设计一个算法来计算你所能获取的最大利润.你可以尽可能地完成更多的交易(多次买卖一支股票). 注意:你不能同时参与多笔交易(你必须在再次 ...

  2. Java实现中文词频统计

    昨日有个中文词频统计的需求, 百度一番后, 发现一大堆标题党文章, 讲的与内容严重不符, 这里就简单记录下自己实现的流程吧! 与英文单词的词频统计不同, 中文的难点在于如何分词, 不过好在有许多优秀的 ...

  3. jQuery源代码学习_工具函数_type

    jquery源代码学习_工具函数_type jquery里面有一个很重要的工具函数,$.type函数用来判断类型,今天写这篇文章,是来回顾type函数的设计思想,深入理解. 首先来看一下最终结果: 上 ...

  4. Ajax原理实现

    jQuery的ajax实现原理: // 1.创建一个XMLHttpRequest对象 var xhr = new XMLHttpRequest(); // 2.打开请求 xhr.open('METHO ...

  5. HDU 1045——Fire Net——————【最大匹配、构图、邻接矩阵做法】

    Fire Net Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Submit Sta ...

  6. HDU 4365——Palindrome graph——————【规律+快速幂】

    Palindrome graph Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) ...

  7. pyhon虚拟环境的安装和使用

    安装Python2.7: 1.Mac下使用Python2.7 2.Windows下安装Python2.7. *从python官网下载python2.7的版本 *双击python2.7,然后选择安装路径 ...

  8. 树莓派ssh报错:WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED解决

    初次使用树莓派,在使用树莓派本机网卡时被DHCP服务器分配到192.168.0.103,连接正常.于是乎很开心的将无线网卡插入树莓派,急于摆脱网线的束缚. ifconfig一下获取无线网卡的MAC地址 ...

  9. 网站架构:消息队列 Java后端架构

    2017-01-13  一.消息队列概述 消息队列中间件是分布式系统中重要的组件,主要解决应用耦合,异步消息,流量削锋等问题.实现高性能,高可用,可伸缩和最终一致性架构.是大型分布式系统不可缺少的中间 ...

  10. gof23 适配器模式

    namespace Adapter { class Program { static void Main(string[] args) { //原实现 ClassBase customa = new ...