创建数组

在ES6之前,创建数组的方式主要有两种:

  • 调用 Array 构造函数
  • 用数组字面量语法

为了简化数组的创建过程,ES6新增了两个方法:

  • Array.of()
  • Array.from()

Array.of() 方法

ES6之所以向JS添加新的数组创建方法,是要帮助开发者们规避通过Array构造函数创建数组时的怪异行为。

let items = new Array(2);
console.log(items.length); // 2
console.log(items[0]);
console.log(items[1]); items = new Array("2");
console.log(items.length); // 1
console.log(items[0]); // "2" items = new Array(1, 2);
console.log(items.length); // 2
console.log(items[0]); // 1
console.log(items[1]); // 2 items = new Array(3, "2");
console.log(items.length); // 2
console.log(items[0]); // 3
console.log(items[1]); // "2"

当传入一个参数时,如果是数值型,那个数组的 length 属性就会设置为该值;如果传入多个值,此时无论这些值是不是数值型的,都会变为数组的元素。这个特性让人感到困惑,你不可能总是注意传入数据的类型。

ES6通过引入 Array.of() 方法来解决这个问题。Array.of() 与 Array 构造函数类似,只是不存在单一数值型参数的特例。无论有多少参数,无论参数是什么类型,Array.of() 方法总会创建一个包含所有参数的数组。

let items = Array.of(1, 2);
console.log(items.length); // 2
console.log(items[0]); // 1
console.log(items[1]); // 2 let items = Array.of(2);
console.log(items.length); // 1
console.log(items[0]); // 2 let items = Array.of("2");
console.log(items.length); // 1
console.log(items[0]); // "2"

Array.from() 方法

将对象转化为数组。

function doSomething() {
var args = Array.from(arguments); console.log(args);
} doSomething(1, 2, 3, 4); // [1, 2, 3, 4]

映射转换

可以提供一个映射函数作为 Array.from() 的第二个参数,这个函数用来将类数组对象中的每一个值转换成其它形式,最后将这些结果储存在结果数组的相应索引中。

function translate() {
return Array.from(arguments, (value) => value + 1);
} let numbers = translate(1, 2, 3);
console.log(numbers); // [2, 3, 4]

如果用映射函数处理对象,也可以给 Array.from() 方法传入第三个参数来表示映射函数的this值。

let helper = {
diff: 1,
add(value) {
return value + this.diff;
}
}; function translate() {
return Array.from(arguments, helper.add, helper);
} let numbers = translate(1, 2, 3);
console.log(numbers); // [2, 3, 4]

用 Array.from() 转换可迭代对象

let numbers = {
*[Symbol.iterator]() {
yield 1;
yield 2;
yield 3;
}
}; let numbers2 = Array.from(numbers, (value) => value + 1);
console.log(numbers2); // [2, 3, 4]

为所有数组添加的新方法

find() 方法和 findIndex() 方法

find() 方法 和 findIndex() 方法都接受两个参数:

  • 回调函数
  • 指定回调函数中的this值,可选参数

执行回调函数时,传入的参数为:

  • 数组中的某个元素
  • 该元素在数组中的索引
  • 数组本身

如果给定的值满足定义的标准,回调函数应返回true,一旦回调函数返回true,find() 方法和 findIndex() 方法都会立即停止搜索数组剩余的部分。

find() 方法返回查找到的值;findeIndex() 方法返回查找到的值的索引。

let numbers = [25, 30, 35, 40, 45];

console.log(numbers.find(n => n > 33)); // 35
console.log(numbers.findIndex(n => n > 33)); // 2

fill() 方法

可以用指定的值填充一至多个数组元素。

let numbers = [1, 2, 3, 4];
numbers.fill(1);
console.log(numbers.toString()); // 1,1,1,1

如果只想改变数组某一部分的值,可以传入开始索引和不包含结束索引(不包含结束索引当前值)这两个可选参数。

let numbers = [1, 2, 3, 4];
numbers.fill(1, 2); // 从索引2开始填充数组
console.log(numbers.toString()); // 1,2,1,1
numbers.fill(0, 1, 3); // 从索引1开始填充到索引2
console.log(numbers.toString()); // 1,0,0,1

Note

如果开始索引或结束索引为负值,name这些值会与数组的length属性相加来作为最终位置。

copyWithin() 方法

从数组复制元素的值。

参数:

  1. 开始填充值的索引位置;
  2. 开始复制值的索引位置;
  3. 指定停止复制值的位置(不包含结束索引)(可选参数)(默认情况下会一直复制到数组末尾的值)
let numbers = [1, 2, 3, 4];

// 从数组的索引2开始粘贴值
// 从数组的索引0开始复制值
numbers.copyWithin(2, 0); console.log(numbers.toString()); // 1,2,1,2
let numbers = [1, 2, 3, 4];

// 从数组的索引2开始粘贴值
// 从数组的索引0开始复制值
// 当位于索引1时停止复制值
numbers.copyWithin(2, 0, 1); console.log(numbers.toString()); // 1,2,1,4

Note

同 fill() 方法一样,copyWithin() 方法的所有参数都接受负数值,并且会自动与数组长度相加来作为最终使用的索引。

定型数组

定型数组时一种用于处理数值类型(不是所有类型)数据的专用数组。

在JavaScript中,数字是以64位浮点格式存储的,并按需转换为32位整数,所以运算非常慢。

在ES6中引入定型数组来解决这个问题,并提供更高性能的算术运算。

定型数组与普通数组最重要的差别是:定型数组不是普通数组。它不继承自Array。

【读书笔记】【深入理解ES6】#10-改进的数组功能的更多相关文章

  1. 深入理解ES6之—增强的数组功能

    创建数组 Array.of()方法 ES6为数组新增创建方法的目的之一,是帮助开发者在使用Array构造器时避开js语言的一个怪异点.Array.of()方法总会创建一个包含所有传入参数的数组,而不管 ...

  2. 20150206读书笔记<深入理解计算机系统>

    ●第一章 C是系统级编程的首选.C++显示支持抽象,属于应用级程序设计语言. 简单例子: 一个典型系统的硬件组成: 存储器的层次结构: 注:存储器层次结构的设计思想是,该层存储器作为下一层存储器的高速 ...

  3. 【读书笔记】2016.12.10 《构建高性能Web站点》

    本文地址 分享提纲: 1. 概述 2. 知识点 3. 待整理点 4. 参考文档 1. 概述 1.1)[该书信息] <构建高性能Web站点>: -- 百度百科 -- 本书目录: 第1章 绪论 ...

  4. Python基础教程【读书笔记】 - 2016/7/10

    希望通过博客园持续的更新,分享和记录Python基础知识到高级应用的点点滴滴! 第五波:第1章  基础知识 [总览]  介绍如何得到所需的软件,然后讲一点点算法及其主要的组成.学习变量variable ...

  5. 《Linux命令行与shell脚本编程大全》- 读书笔记3 - 理解shell

    当用户登录终端的时候,通常会启动一个默认的交互式shell.系统究竟启动哪个shell,这取决于用户配置.一般这个shell都是/bin/shell.默认的系统shell(/bin/sh)用于系统sh ...

  6. python 进阶读书笔记1 -- 理解python一切皆对象

    理解python一切皆对象: 1.所有的类都是由type创建的 2.所有的类的基类都是object 3.type是类,也是实例,type的基类是object,type对象是由type创建的 4.obj ...

  7. 【读书笔记::深入理解linux内核】内存寻址【转】

    转自:http://www.cnblogs.com/likeyiyy/p/3837272.html 我对linux高端内存的错误理解都是从这篇文章得来的,这篇文章里讲的 物理地址 = 逻辑地址 – 0 ...

  8. 【读书笔记::深入理解linux内核】内存寻址

    我对linux高端内存的错误理解都是从这篇文章得来的,这篇文章里讲的 物理地址 = 逻辑地址 – 0xC0000000:这是内核地址空间的地址转换关系. 这句话瞬间让我惊呆了,根据我的CPU的知识,开 ...

  9. 20150207读书笔记<深入理解计算机系统2-1>

    第二章 信息存储 (1)  多数计算机以一个字节作为最小可寻址的存储器单元. 机器级程序将存储器看成一个非常大的字节数组,称为虚拟存储器. 存储器的每个字节都由唯一的数字标识,称为它的地址. 所有可能 ...

  10. 读书笔记 effective c++ Item 10 让赋值运算符返回指向*this的引用

    一个关于赋值的有趣的事情是你可以将它们链在一起: int x, y, z; x = y = z = ; // chain of assignments 同样有趣的是赋值采用右结合律,所以上面的赋值链被 ...

随机推荐

  1. 【 全干货 】5 分钟带你看懂 Docker !

    欢迎大家前往腾讯云社区,获取更多腾讯海量技术实践干货哦~ 作者丨唐文广:腾讯工程师,负责无线研发部地图测试. 导语:Docker,近两年才流行起来的超轻量级虚拟机,它可以让你轻松完成持续集成.自动交付 ...

  2. springMVC学习总结(四)springmvc处理json数据类型以及fastjson的使用

    springMVC学习总结(四)springmvc处理json数据类型以及fastjson的使用 主要内容: 这篇文章主要是总结之前使用springmv接收json的时候遇到的问题,下面通过前台发送a ...

  3. 大数据学习(2)HDFS文件管理

    命令行管理HDFS [root@server1 bin]# hadoop fs Usage: hadoop fs [generic options] [-appendToFile <locals ...

  4. 让你高效的理解JavaScript中的同步、异步和事件循环

    "同步请求","异步请求"相信这两词在程序猿的世界中频频出现,到底是词性的妖娆,还是撸代码的基础要求,下面直接分享本人学习的好东西,保证让你深入浅出,爽得不要不 ...

  5. Javascript中的Microtask和Macrotask——从一道很少有人能答对的题目说起

    首先我们来看一道题目,如下javascript代码,执行后会在控制台打印出什么内容? async function async1() { console.log('async1 start'); aw ...

  6. iOS实现类似QQ的好友列表,自由展开折叠(在原来TableView的基础上添加一个字典,一个Button)

    //直接代码 只包含 折叠展开字典的处理搭建#import "CFViewController.h" @interface CFViewController ()<UITab ...

  7. CET——4 常用短语

    在网上看到的,先拔到自己这来,四级大大,求过!!!!

  8. Java 本地开发环境搭建(框架采用 Spring+Spring MVC+Hibernate+Jsp+Gradle+tomcat+mysql5.6)

    项目搭建采用技术栈为:Spring+Spring MVC+Hibernate+Jsp+Gradle+tomcat+mysql5.6 搭建环境文档目录结构说明: 使用Intellj Idea 搭建项目过 ...

  9. CJOJ 免费航班

    Description 小Z在MOI比赛中获得了大奖,奖品是一张特殊的机 票.使用这张机票,可以在任意一个国家内的任意城市之间的免费飞行,只有跨国飞行时才会有额外的费用.小Z获得了一张地图,地图上有城 ...

  10. 限制ssh远程登陆

    超过十次,就添加到hosts.deny里面去 #!/bin/bash date=`date +%Y%m%d` file="/var/log/secure" max=10 if [[ ...