当前位置:山东群英会技巧>文章>JavaScript

ES6扩展运算符的用途

山东群英会技巧 www.iba5.com.cn ES6的扩展运算符可以说是非常使用的,在给多参数函数传参,替代Apply,合并数组,和解构配合进行赋值方面提供了很好的便利性。

扩展运算符就是三个点“...”,就是将实现了Iterator 接口的对象中的每个元素都一个个的迭代并取出来变成单独的被使用。

看这个例子:

console.log(...[3, 4, 5])

结果:

3 4 5

调用其实就是:

console.log(3, 4, 5)

 

合并数组
可以使用扩展运算符将多个数组进行合并。
let arr1 = [1, 2, 3]
let arr2 = [4, 5, 6]
let arr3 = [7, 8, 9]
console.log([...arr1, ...arr2, ...arr3])

结果:

[ 1, 2, 3, 4, 5, 6, 7, 8, 9 ]

 

函数多参数传递, 替换Apply
先把参数定义成数组,函数定义好。
let arr4 = ['arg1', 'arg2', 'arg3', 'arg4']
let fun1 = (a1, a2, a3, a4) => {
  console.log( a1, a2, a3, a4)
}

在ES6前,要把数组参数传递给函数,要么按照下标访问数组元素去调用函数,缺点是数组个数和函数参数个数完全绑定,有一个个数发生变化,那么就要修改了。

fun1(arr4[0], arr4[1], arr4[2], arr4[3])

要么就用Apply进行调用,结果当然是没毛病,也是ES6之前用的最多的。

fun1.apply(null, arr4)

如果是用扩展运算符,那就方便咯。

fun1(...arr4)

结果:

arg1 arg2 arg3 arg4

调用简洁爽快。

 

与解构配合赋值
配合使用,可以从数组中提取除第一个以后的所有元素成另外一个数组。
let [var1, ...arr5] = [1, 2, 3, 4, 5, 6]
console.log(var1)
console.log(arr5)

结果:

1[ 2, 3, 4, 5, 6 ]

但要注意,与解构配合时,扩展运算符只能用在最后一个上,否则报错。

 

可以展开实现了Iterator 接口的对象
比如Map,Set,数组就是从Iterator接口实现来的,Object不是,所以扩展Object会报错。
扩展Set。
let set1 = new Set()
set1.add(1)
set1.add(2)
set1.add(3)
console.log(...set1)

结果:

1 2 3

 

扩展Map。

let map1 = new Map();
map1.set('k1', 1);
map1.set('k2', 2);
map1.set('k3', 3);
console.log(...map1)

结果:

[ 'k1', 1 ] [ 'k2', 2 ] [ 'k3', 3 ]

注意,扩展出来的一个个的数组,按照map的键值对结构,每个数组都是2个元素,一个是key,一个是value。

 

如果扩展Object,就会报错。

let obj1 = {
   p1: 1,
   p2: 2,
   p3: 3}
console.log(...obj1)

报错。

 


相关阅读:

  • 尊重网络主权 发扬伙伴精神 2019-06-15
  • 打造-热门标签-华商生活 2019-06-07
  • 童国华委员:预计今年下半年5G进入规模试验阶段 2019-05-26
  • 中信国安葡萄酒业携尼雅等明星产品亮相首届中国自主品牌博览会 2019-05-25
  • 黑龙江严肃对待督察整改工作 2019-05-23
  • 可再生能源电价附加资金补助目录公布 2019-05-22
  • 关于益寿丹 竹林日记(0073) 2019-05-21
  • 中考TIPS 带证防雨留意天气变化 2019-05-21
  • 玉龙雪山、纳西风情…丽江旅游:卖的不是门票而是文化 未来积极融入东南亚旅游圈 2019-05-08
  • 市人大常委会召开党组会议传达学习全国两会精神张轩主持并讲话 2019-05-07
  • [囧][猜想]这有啥好战的? 2019-05-06
  • 廉政教育--安徽频道--人民网 2019-05-05
  • [鼓掌]小撸又来卖萌?那你给大家讲讲? 2019-05-04
  • 手机流量大战套路:“不限量”都是有条件的 2019-05-04
  • 按照马克思的原义,共产主义是"以每一个个人的全面而自由的发展为基本原则的社会形式"。这一基本原则的实现,涉及社会政治、经济、文化等方方面面。离开这一基本原则侈谈 2019-05-03
  • 306| 445| 306| 85| 214| 994| 901| 778| 994| 962| 757| 571| 842| 150| 215|