ES6 - 数组

扩展运算符

将数组转为逗号分隔的参数序列
可以将有 iterator 接口的数据结构转为数组,如 Arguments、NodeList 等
主要用于函数调用,可以替代函数的 apply 方法

运用:
求一个数组的最大元素:
// ES5 的写法
Math.max.apply(null, [14, 3, 77])

// ES6 的写法
Math.max(...[14, 3, 77])


把一个数组的元素 push 进另一个数组
// ES5的 写法
var arr1 = [0, 1, 2];
var arr2 = [3, 4, 5];
Array.prototype.push.apply(arr1, arr2);

// ES6 的写法
let arr1 = [0, 1, 2];
let arr2 = [3, 4, 5];
arr1.push(...arr2);
复制数组:
// ES5
const a2 = a1.concat();
// ES6
const a2 = [...a1];

合并数组:
const arr1 = ['a', 'b'];
const arr2 = ['c'];
const arr3 = ['d', 'e'];

// ES5 的合并数组
arr1.concat(arr2, arr3);
// ES6 的合并数组
[...arr1, ...arr2, ...arr3]

把字符串转为数组:
[...'hello']

扩展运算内部调用的是Iterator接口,因此只要具有Iterator接口的对象,都可以使用扩展运算符转为数组,如 Set / Map / Generator函数返回的结果等

Array.from()

可以将两类对象转为数组:array-like 和 iterable
可以接受第二个参数,作用类似 map:

Array.from([1, 2, 3], (x) => x * x)
// [1, 4, 9]
// 等同于
Array.from(arrayLike).map(x => x * x);

其它

fill() 使用给定值,填充一个数组

new Array(3).fill(7)
// [7, 7, 7]

entries(),keys() 和 values() 返回的是 Iterator 对象,可以使用 for...of 遍历
flat(Infinity) 可以将嵌套的数组拉平,参数指定想要拉平的层数

你可能感兴趣的:(ES6 - 数组)