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

发布时间 - 2026-01-11 02:52:34    点击率:

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扩展运算符的用途,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!


# ES6扩展运算符的用途  # ES6扩展运算符  # JavaScript 管道运算符及工作原理  # JavaScript扩展运算符的学习及应用详情(ES6)  # JavaScript ES6解构运算符的理解和运用  # JS ES6展开运算符的几个妙用  # JavaScript 扩展运算符用法实例小结【基于ES6】  # 基于es6三点运算符的使用方法(实例讲解)  # ES6中的rest参数与扩展运算符详解  # JS ES6中的管道运算符详解  # 运算符  # 报错  # 小编  # 都是  # 实现了  # 就会  # 很好  # 第一个  # 那就  # 多个  # 最多  # 是从  # 要把  # 给大家  # 可以使用  # 另外一个  # 就用  # 先把  # 用在  # 但要 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 详解Android中Activity的四大启动模式实验简述  java获取注册ip实例  Android仿QQ列表左滑删除操作  软银砸40亿美元收购DigitalBridge 强化AI资料中心布局  Laravel如何使用Gate和Policy进行授权?(权限控制)  高性能网站服务器配置指南:安全稳定与高效建站核心方案  Laravel如何使用查询构建器?(Query Builder高级用法)  网页设计与网站制作内容,怎样注册网站?  简单实现Android文件上传  如何彻底卸载建站之星软件?  网站建设整体流程解析,建站其实很容易!  Laravel如何获取当前用户信息_Laravel Auth门面获取用户ID  🚀拖拽式CMS建站能否实现高效与个性化并存?  详解Oracle修改字段类型方法总结  Laravel如何使用Facades(门面)及其工作原理_Laravel门面模式与底层机制  浅谈Javascript中的Label语句  Laravel如何实现图片防盗链功能_Laravel中间件验证Referer来源请求【方案】  Laravel如何获取当前登录用户信息_Laravel Auth门面使用与Session用户读取【技巧】  Laravel怎么进行浏览器测试_Laravel Dusk自动化浏览器测试入门  如何快速搭建高效服务器建站系统?  Laravel如何监控和管理失败的队列任务_Laravel失败任务处理与监控  javascript基本数据类型及类型检测常用方法小结  laravel怎么配置Redis作为缓存驱动_laravel Redis缓存配置教程  个人网站制作流程图片大全,个人网站如何注销?  Laravel怎么使用Session存储数据_Laravel会话管理与自定义驱动配置【详解】  Gemini怎么用新功能实时问答_Gemini实时问答使用【步骤】  图片制作网站免费软件,有没有免费的网站或软件可以将图片批量转为A4大小的pdf?  Linux虚拟化技术教程_KVMQEMU虚拟机安装与调优  佛山网站制作系统,佛山企业变更地址网上办理步骤?  JavaScript如何实现类型判断_typeof和instanceof有什么区别  Laravel如何与Pusher实现实时通信?(WebSocket示例)  北京企业网站设计制作公司,北京铁路集团官方网站?  Midjourney怎么调整光影效果_Midjourney光影调整方法【指南】  Bootstrap整体框架之JavaScript插件架构  制作公司内部网站有哪些,内网如何建网站?  如何快速辨别茅台真假?关键步骤解析  如何在Tomcat中配置并部署网站项目?  手机怎么制作网站教程步骤,手机怎么做自己的网页链接?  什么是JavaScript解构赋值_解构赋值有哪些实用技巧  Windows家庭版如何开启组策略(gpedit.msc)?(安装方法)  进行网站优化必须要坚持的四大原则  昵图网官方站入口 昵图网素材图库官网入口  如何快速搭建个人网站并优化SEO?  Laravel如何为API生成Swagger或OpenAPI文档  阿里云网站搭建费用解析:服务器价格与建站成本优化指南  猎豹浏览器开发者工具怎么打开 猎豹浏览器F12调试工具使用【前端必备】  php485函数参数是什么意思_php485各参数详细说明【介绍】  怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?  魔毅自助建站系统:模板定制与SEO优化一键生成指南  如何登录建站主机?访问步骤全解析