0

0

javascript的展开运算符是什么_有哪些实用场景【教程】

夜晨

夜晨

发布时间:2026-01-25 18:07:30

|

373人浏览过

|

来源于php中文网

原创

展开运算符...用于将可迭代对象摊开为独立元素,不直接操作普通对象;数组浅拷贝、合并时需注意引用共享;对象展开仅处理自有可枚举属性,同名属性后覆盖前,不递归、不处理不可枚举项及原型链。

javascript的展开运算符是什么_有哪些实用场景【教程】

展开运算符 ... 是什么?它不是万能的复制工具

JavaScript 的 ...(展开运算符)本质是「将可迭代对象(如数组、字符串、Map、Set)或类数组对象「摊开」成独立元素」。它不直接操作对象,对普通对象使用时会报错 TypeError: Found non-callable @@iterator,除非该对象实现了 Symbol.iterator。注意:它和剩余参数(...args)语法相同但语义相反——一个「往外摊」,一个「往里收」。

数组合并与浅拷贝:别用 push(...arr) 往原数组塞

常见误用是想把一个数组所有元素推入另一个数组,却写成 target.push(...source)。这确实可行,但要注意:push 会修改原数组;若只想生成新数组,更推荐 [...target, ...source]。另外,[...arr] 只做一层浅拷贝,嵌套对象/数组仍共享引用。

  • const a = [1, 2]; const b = [...a, 3, 4]; // [1, 2, 3, 4]
  • const c = [[1], [2]]; const d = [...c]; d[0].push(9); console.log(c); // [[1, 9], [2]] —— 原数组被改了
  • 替代深拷贝?不行。要用 JSON.parse(JSON.stringify(arr)) 或结构化克隆(structuredClone

函数调用传参:比 apply 更直观,但不能替代 bind

展开运算符让动态传参变得自然,尤其适合已知参数在数组中时。但它无法像 bind 那样预设部分参数并返回新函数。

飞书多维表格
飞书多维表格

表格形态的AI工作流搭建工具,支持批量化的AI创作与分析任务,接入DeepSeek R1满血版

下载
  • Math.max(...[3, 7, 2]) // 7,等价于 Math.max(3, 7, 2)
  • const args = ['a', 'b']; func(...args); // ✅
  • const bound = func.bind(null, ...args); // ❌ 语法错误 —— bind 不接受展开表达式作为参数列表
  • 正确做法:const bound = (...rest) => func(...args, ...rest);

对象展开:只处理自有可枚举属性,且顺序可能影响结果

对象展开({...obj})实际是按属性遍历顺序(ES2015+ 规定:数字键升序 → 字符串键插入顺序 → Symbol 键插入顺序)逐个赋值。后出现的同名属性会覆盖前面的。

立即学习Java免费学习笔记(深入)”;

  • const a = { x: 1, y: 2 }; const b = { y: 3, z: 4 }; const c = { ...a, ...b }; // { x: 1, y: 3, z: 4 }
  • 不可枚举属性(如 Object.defineProperty(obj, 'hidden', { value: 5, enumerable: false }))不会被展开
  • 原型链上的属性也不会被展开 —— 它只取对象自身的可枚举属性
  • 遇到 getter/setter?会执行 getter 获取值,但 setter 不会被触发
展开运算符看着简单,但真正用稳需要清楚它在哪「停步」:不递归、不处理不可枚举项、不保留原型、不兼容非可迭代对象。很多 bug 都源于默认它「全量复制」。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

457

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

547

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

335

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

82

2025.09.10

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

254

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

1089

2024.03.01

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1567

2023.10.24

Go语言中的运算符有哪些
Go语言中的运算符有哪些

Go语言中的运算符有:1、加法运算符;2、减法运算符;3、乘法运算符;4、除法运算符;5、取余运算符;6、比较运算符;7、位运算符;8、按位与运算符;9、按位或运算符;10、按位异或运算符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

241

2024.02.23

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 6万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.4万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号