你以为你懂 ...?其实坑才刚开始!

前言

在前端圈里,有一个操作符被称作「万能胶水」,有点像哆啦 A 梦的百宝袋,什么都能掏出来,它就是 JavaScript 的扩展运算符 ...,俗称"三点运算符"。

null

虽然看起来只是三个小点点,但用好了,代码能优雅到飞起;用不好,就像胶水乱涂一通,搞得代码又黏又臭。

今天,我们就来盘一盘这三个点到底都能干啥,有啥坑,又该怎么写得更优雅。


数组的"复制+拼接",so easy!

很多时候我们想复制数组,或者合并多个数组。如果你还在用 sliceconcat,那你真的可以退休了:

✅ 替代 slice

ini 复制代码
const original = [1, 2, 3];
const copy = [...original];
console.log(copy); // [1, 2, 3]

这样复制是浅拷贝,不会影响原数组:

ini 复制代码
copy[0] = 100;
console.log(original[0]); // 依然是 1

✅ 合并数组:

ini 复制代码
const a = [1, 2];
const b = [3, 4];
const merged = [...a, ...b];
console.log(merged); // [1, 2, 3, 4]

是不是比 concat() 更清爽?


对象的合并与重写,更丝滑

扩展运算符也能用于对象,但它的行为有点不同:它是按键名覆盖,后面的会覆盖前面的。

ini 复制代码
const base = { a: 1, b: 2 };
const update = { b: 3, c: 4 };

const result = { ...base, ...update };
console.log(result); // { a: 1, b: 3, c: 4 }

🎯 小心坑!

当对象内嵌结构(比如嵌套对象、数组)时,还是浅拷贝哦!

ini 复制代码
const obj = { a: { x: 1 } };
const clone = { ...obj };
clone.a.x = 999;
console.log(obj.a.x); // 999,惊不惊喜?

解决方案:用 structuredClonelodash.cloneDeep 或手撸递归。


函数的参数魔术:rest & spread

这三个点还能玩点参数魔法:

✅ spread(拆开参数):

ini 复制代码
const nums = [1, 2, 3];
console.log(Math.max(...nums)); // 3

等价于 Math.max(1, 2, 3),拆得明明白白。

✅ rest(打包参数):

javascript 复制代码
function sum(...args) {
  return args.reduce((acc, val) => acc + val, 0);
}
console.log(sum(1, 2, 3, 4)); // 10

你可以把任意数量的参数打包进数组,超适合做工具函数。


数组解构的隐藏技巧

... 解构数组时,你可以捕获"剩余"的部分,就像用网捞鱼一样:

scss 复制代码
const [head, ...tail] = [10, 20, 30];
console.log(head); // 10
console.log(tail); // [20, 30]

这在处理响应数据时非常高效,比如:

ini 复制代码
const [first, ...rest] = data.list;

处理主数据和副数据,优雅又清晰。


你可能没注意的细节 ⚠️

❌ 不能乱用在对象中间:

csharp 复制代码
const obj = { a: 1, ...null }; // ❌ 会报错

✅ 可以用在数组/对象的函数参数中:

css 复制代码
function logAll(a, b, ...rest) {
  console.log(a, b, rest);
}
logAll(1, 2, 3, 4); // 1 2 [3, 4]

✍️ 总结

扩展运算符 ... 其实就是 JavaScript 世界的"万能钥匙"。拼接、解构、打包、展开,一个符号搞定各种场景。

但也别盲目崇拜,像对象嵌套那种场景它就无能为力了。掌握它、理解它、敬畏它,才能写出既简洁又健壮的代码。

相关推荐
San30.2 分钟前
现代前端工程化实战:从 Vite 到 Vue Router 的构建之旅
前端·javascript·vue.js
sg_knight2 分钟前
模块热替换 (HMR):前端开发的“魔法”与提速秘籍
前端·javascript·vue·浏览器·web·模块化·hmr
A24207349303 分钟前
js常用事件
开发语言·前端·javascript
LV技术派4 分钟前
适合很多公司和团队的 AI Coding 落地范式(一)
前端·aigc·ai编程
Fighting_p7 分钟前
【导出】前端 js 导出下载文件时,文件名前后带下划线问题
开发语言·前端·javascript
WYiQIU7 分钟前
从今天开始备战1月中旬的前端寒假实习需要准备什么?(飞书+github+源码+题库含答案)
前端·javascript·面试·职场和发展·前端框架·github·飞书
skywalk81638 分钟前
waveterm一款 跨平台、基于 Web 的现代终端
前端·waveterm
摸鱼少侠梁先生10 分钟前
通过接口获取字典的数据进行渲染
前端·javascript·vue.js
大卡拉米10 分钟前
前端组件库 PDF、word、Excel预览
前端·pdf·word
小满zs20 分钟前
Next.js第十四章(缓存策略)
前端