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 相关文章推荐
Tab页界面 用jQuery及Ajax技术实现(php后台)
Oct 12 Javascript
JS读取XML文件示例代码
Nov 15 Javascript
Javascript的严格模式strict mode详细介绍
Jun 06 Javascript
jQuery中[attribute*=value]选择器用法实例
Dec 31 Javascript
jQuery Ajax中的事件详细介绍
Apr 16 Javascript
jquery选择器简述
Aug 31 Javascript
详解Angularjs中的依赖注入
Mar 11 Javascript
dul无法加载bootstrap实现unload table/user恢复
Sep 29 Javascript
vue2.0全局组件之pdf详解
Jun 26 Javascript
ajax请求+vue.js渲染+页面加载的示例
Feb 11 Javascript
详解新手使用vue-router传参时注意事项
Jun 06 Javascript
Ajax请求时无法重定向的问题解决代码详解
Jun 21 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
PHP导出EXCEL快速开发指南--PHPEXCEL的使用详解
2013/06/03 PHP
PHP中防止SQL注入方法详解
2014/12/25 PHP
php实现微信公众号创建自定义菜单功能的实例代码
2019/06/11 PHP
增强的 JavaScript 的 trim 函数的代码
2007/08/13 Javascript
利用javascript判断文件是否存在
2013/12/31 Javascript
使用delegate方法为一个tr标签加一个链接
2014/06/27 Javascript
简单谈谈Javascript中类型的判断
2015/10/19 Javascript
基于Jquery easyui 选中特定的tab
2015/11/17 Javascript
基于javascript显示当前时间以及倒计时功能
2016/03/18 Javascript
扩展jquery easyui tree的搜索树节点方法(推荐)
2016/10/28 Javascript
原生js实现旋转木马轮播图效果
2017/02/27 Javascript
基于ionic实现下拉刷新功能
2018/05/10 Javascript
监听angularJs列表数据是否渲染完毕的方法示例
2018/11/07 Javascript
基于jquery实现九宫格拼图小游戏
2018/11/30 jQuery
简单的React SSR服务器渲染实现
2018/12/11 Javascript
NodeJs操作MongoDB教程之分页功能以及常见问题
2019/04/09 NodeJs
微信小程序获取用户绑定手机号方法示例
2019/07/21 Javascript
微信小程序实现打卡签到页面
2020/09/21 Javascript
[43:03]LGD vs Newbee 2019国际邀请赛小组赛 BO2 第一场 8.16
2019/08/19 DOTA
python3使用SMTP发送HTML格式邮件
2018/06/19 Python
Python Web框架之Django框架cookie和session用法分析
2019/08/16 Python
python爬虫之爬取百度音乐的实现方法
2019/08/24 Python
Python可变参数会自动填充前面的默认同名参数实例
2019/11/18 Python
Python作用域与名字空间原理详解
2020/03/21 Python
Python3操作YAML文件格式方法解析
2020/04/10 Python
使用Keras构造简单的CNN网络实例
2020/06/29 Python
HTML5自定义属性前缀data-及dataset的使用方法(html5 新特性)
2017/08/24 HTML / CSS
教学质量评估实施方案
2014/03/17 职场文书
班级心理活动总结
2014/07/04 职场文书
党员四风自我剖析材料思想汇报
2014/09/13 职场文书
幼儿园个人师德总结
2015/02/06 职场文书
2015年七年级班主任工作总结
2015/05/21 职场文书
总结Pyinstaller打包的高级用法
2021/06/28 Python
python获取对象信息的实例详解
2021/07/07 Python
TV动画《神废柴☆偶像》公布先导PV
2022/03/20 日漫
nginx之内存池的实现
2022/06/28 Servers