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 相关文章推荐
学习YUI.Ext第五日--做拖放Darg&Drop
Mar 10 Javascript
jQuery 研究心得 取得属性的值
Nov 30 Javascript
Javascript面向对象编程
Mar 18 Javascript
三种检测iPhone/iPad设备方向的方法
Apr 23 Javascript
JavaScript使用slice函数获取数组部分元素的方法
Apr 06 Javascript
JS获取图片高度宽度的方法分享
Apr 17 Javascript
基于javascript实现泡泡大冒险网页版小游戏
Mar 23 Javascript
AngularJS ui-router (嵌套路由)实例
Mar 10 Javascript
vue项目中导入swiper插件的方法
Jan 30 Javascript
详解Vue调用手机相机和相册以及上传
May 05 Javascript
JS+CSS+HTML实现“代码雨”类似黑客帝国文字下落效果
Mar 17 Javascript
实例讲解JavaScript 计时事件
Jul 04 Javascript
关于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
8个出色的WordPress SEO插件收集
2011/02/26 PHP
xml在joomla表单中的应用详解分享
2012/07/19 PHP
PHP独立Session数据库存储操作类分享
2014/06/11 PHP
php结合js实现点击超链接执行删除确认操作
2014/10/31 PHP
PHP实现加密的几种方式介绍
2015/02/22 PHP
php身份证号码检查类实例
2015/06/18 PHP
php 实现进制相互转换
2016/04/07 PHP
深入认识JavaScript中的函数
2007/01/22 Javascript
基于jquery的表格排序
2010/09/11 Javascript
javascript的console.log()用法小结
2012/05/31 Javascript
简单几行JS Code实现IE邮件转发新浪微博
2013/07/03 Javascript
javascript替换已有元素replaceChild()使用介绍
2014/04/03 Javascript
JavaScript数据类型判定的总结笔记
2015/07/31 Javascript
jQuery实现的导航动画效果(附demo源码)
2016/04/01 Javascript
JavaScript严格模式详解
2017/01/16 Javascript
详解vue 自定义组件使用v-model 及探究其中原理
2019/10/11 Javascript
如何使用JavaScript检测空闲的浏览器选项卡
2020/05/28 Javascript
vue.js实现h5机器人聊天(测试版)
2020/07/16 Javascript
Python文件去除注释的方法
2015/05/25 Python
在Django中进行用户注册和邮箱验证的方法
2016/05/09 Python
python numpy 部分排序 寻找最大的前几个数的方法
2018/06/27 Python
Django框架封装外部函数示例
2019/05/28 Python
Django项目中使用JWT的实现代码
2019/11/04 Python
Python笔记之代理模式
2019/11/20 Python
详解从Django Allauth中进行登录改造小结
2019/12/18 Python
python 数据库查询返回list或tuple实例
2020/05/15 Python
Python通过kerberos安全认证操作kafka方式
2020/06/06 Python
Python DES加密实现原理及实例解析
2020/07/17 Python
美国购车网站:TrueCar
2016/10/19 全球购物
请用用Java代码写一个堆栈
2012/01/26 面试题
关于递归的一道.NET面试题
2013/05/12 面试题
linux比较文件内容的命令是什么
2015/09/23 面试题
2015年乡镇统计工作总结
2015/04/22 职场文书
字典算法实现及操作 --python(实用)
2021/03/31 Python
Python中的np.argmin()和np.argmax()函数用法
2021/06/02 Python
Python内置的数据类型及使用方法
2022/04/13 Python