es6 扩展运算符(…)及转化为数组的方法

#es6 扩展运算符(…)

1.合并数组

es6写法
const a1 = [1, 2, 3], a2 = [4], a3 = [5, 6];
const b = [...a1, ...a2, ...a3] // [1, 2, 3, 4, 5, 6]
es5写法
a1.concat(a2, a3) // [1, 2, 3, 4, 5, 6]

2.解构赋值

es6写法
const [first, ...rest] = [1, 2, 3, 4, 5, 6];
first // 1
rest // [2, 3, 4, 5, 6]
es5写法
var a = [1, 2, 3, 4, 5, 6,];
first = a[0] // 1
rest = a.slice(1) // [2, 3, 4, 5, 6]

扩展运算符运用于数组赋值,只能放在参数的最后一位,否则报错

const [first, ...middle, last] = [1, 2, 3, 4, 5] //报错

3.将字符串转为真正的数组

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

4.实现iterator接口的对象

 (...)背后调用的是遍历器接口,所以任何有iterator的对象都可以用(...)转化为真正的数组
 
const nodelist = document.querySelectorAll('div'); //nodelist是类似数组的对象
const array = [...nodelist]

#其他两个转化为数组的方法

Array.from()可将两类对象转为数组:
类似数组对象(不管有无Iterator接口, 本质特征有length属性)、可遍历对象。

const arrayLike = {
  '0': 'a',
  '1': 'b',
  '2': 'c',
  length: 3
}
const array = Array.from(arratLike) // ['a', 'b', 'c']

Array.from()可接受第二个参数,作用类似于数组的map方法,对每个元素进行处理,并放入返回的数组中。
const spans = document.querySelectorAll('span'); //nodelist是类似数组的对象
const array = Array.from(spans, s => s.textContent);
Array.of()也可以将一组值转化为数组,弥补Array()的不足.
Array()的不足:
Array(3) //['', '' , '']
Array(3, 2, 1) // [3, 2, 1]
当Array只有一个参数时,实际上指的是数组的长度,并不能返回length=1的数组
Array.of()不存在因为参数的不同导致的重载,基本上可以代替Array()或new Array()
Array.of(3) //[3]
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值