ES6扩展运算符的用途实例详解


Posted in Javascript onAugust 20, 2017

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)

报错。

总结

以上所述是小编给大家介绍的ES6扩展运算符的用途,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

Javascript 相关文章推荐
不用写JS也能使用EXTJS视频演示
Dec 29 Javascript
Javascript 圆角div的实现代码
Oct 15 Javascript
jquery删除ID为sNews的tr元素的内容
Apr 10 Javascript
node+express+jade制作简单网站指南
Nov 26 Javascript
深入探究使JavaScript动画流畅的一些方法
Jun 30 Javascript
Javascript实现图片懒加载插件的方法
Oct 20 Javascript
jquery仿苹果的时间/日期选择效果
Mar 08 Javascript
js轮播图透明度切换(带上下页和底部圆点切换)
Apr 27 Javascript
vue实现跨域的方法分析
May 21 Javascript
JS中封装axios来管控api的2种方式
Sep 11 Javascript
javascript 高级语法之继承的基本使用方法示例
Nov 11 Javascript
JQuery表单元素取值赋值方法总结
May 12 jQuery
关于JavaScript的单双引号嵌套问题
Aug 20 #Javascript
Vue动态组件实例解析
Aug 20 #Javascript
jQuery实现表格冻结顶栏效果
Aug 20 #jQuery
Vue组件实例间的直接访问实现代码
Aug 20 #Javascript
JavaScript贪吃蛇小组件实例代码
Aug 20 #Javascript
React Native 环境搭建的教程
Aug 19 #Javascript
ionic App问题总结系列之ionic点击系统返回键退出App
Aug 19 #Javascript
You might like
PHP利用正则表达式将相对路径转成绝对路径的方法示例
2017/02/28 PHP
解决PHPstudy Apache无法启动的问题【亲测有效】
2020/10/30 PHP
Nigma vs Alliance BO5 第三场2.14
2021/03/10 DOTA
js操作ajax返回的json的注意问题!
2010/02/23 Javascript
日期处理的js库(迷你版)--自建js库总结
2011/11/21 Javascript
常用Extjs工具:Extjs.util.Format使用方法
2012/03/22 Javascript
javascript 构造函数强制调用经验总结
2012/12/02 Javascript
js与jquery获取父元素,删除子元素的两种不同方法
2014/01/09 Javascript
javascript+canvas制作九宫格小程序
2014/12/28 Javascript
Vue.js每天必学之组件与组件间的通信
2016/09/08 Javascript
node.js缺少mysql模块运行报错的解决方法
2016/11/13 Javascript
Bootstrap Modal对话框如何在关闭时触发事件
2016/12/02 Javascript
如何将你的AngularJS1.x应用迁移至React的方法
2018/02/01 Javascript
vue的传参方式汇总和router使用技巧
2018/05/22 Javascript
js的新生代垃圾回收知识点总结
2019/08/22 Javascript
Vue v-for循环之@click点击事件获取元素示例
2019/11/09 Javascript
[01:03:42]VP vs VGJ.S 2018国际邀请赛小组赛BO2 第一场 8.19
2018/08/21 DOTA
实例解析Python中的__new__特殊方法
2016/06/02 Python
python自带的http模块详解
2016/11/06 Python
Python 文件处理注意事项总结
2017/04/10 Python
Python 实现12306登录功能实例代码
2018/02/09 Python
Python面向对象基础入门之编码细节与注意事项
2018/12/11 Python
python3 property装饰器实现原理与用法示例
2019/05/15 Python
解决Python计算矩阵乘向量,矩阵乘实数的一些小错误
2019/08/26 Python
浅谈tensorflow使用张量时的一些注意点tf.concat,tf.reshape,tf.stack
2020/06/23 Python
如何在 Matplotlib 中更改绘图背景的实现
2020/11/26 Python
基于CSS3制作立体效果导航菜单
2016/01/12 HTML / CSS
微信小程序之html5 canvas绘图并保存到系统相册
2019/06/20 HTML / CSS
goodhealth官方海外旗舰店:新西兰国民营养师
2017/12/15 全球购物
数控加工专业毕业生自荐信
2013/09/27 职场文书
浙大毕业生自荐信
2014/01/26 职场文书
校园活动策划方案
2014/06/13 职场文书
2015年学生会干事工作总结
2015/04/09 职场文书
专职安全员岗位职责
2015/04/11 职场文书
广播体操比赛主持词
2015/06/29 职场文书
Python利用capstone实现反汇编
2022/04/06 Python