`...` 展开运算符(Spread Operator)详解

🎯 一句话解释

...arr 的作用是:把数组"拆开",变成一个个独立的元素


📦 对比:有 ... vs 没 ...

javascript 复制代码
let arr = [1, 2, 3];

// ❌ 没有 ... (传进去的是整个数组)
Math.min(arr);  
// 等同于:Math.min([1, 2, 3]) 
// 结果:NaN ❌(Math.min 不认识数组)

// ✅ 有 ... (把数组拆开成独立元素)
Math.min(...arr);  
// 等同于:Math.min(1, 2, 3) 
// 结果:1 ✅

🔄 展开过程可视化

javascript 复制代码
let arr = ["12.50", "3.25", "9.75"];

// ...arr 展开后:
Math.min(...arr);
// 👇 变成了:
Math.min("12.50", "3.25", "9.75");
// 👇 再配合 map(Number) 变成:
Math.min(12.50, 3.25, 9.75);
// 结果:3.25 ✅

🆚 更多对比例子

代码 等同于 结果
Math.min([1, 2, 3]) Math.min([1, 2, 3]) NaN
Math.min(...[1, 2, 3]) Math.min(1, 2, 3) 1
Math.max(5, 8, 2) 本身就是多个参数 8
Math.max(...[5, 8, 2]) Math.max(5, 8, 2) 8

💡 为什么需要 ...

因为 Math.min() / Math.max() 期望接收的是多个独立的数字参数,而不是一个数组:

javascript 复制代码
// ✅ 这种写法 Math.min 能看懂
Math.min(1, 2, 3, 4, 5);

// ❌ 这种写法 Math.min 看不懂
Math.min([1, 2, 3, 4, 5]);

// ✅ 用 ... 把数组"打散"成独立参数
Math.min(...[1, 2, 3, 4, 5]);

🔧 ... 的其他用法

🔹 1. 合并数组

javascript 复制代码
let a = [1, 2];
let b = [3, 4];
let c = [...a, ...b];  // [1, 2, 3, 4]

🔹 2. 复制数组

javascript 复制代码
let arr = [1, 2, 3];
let copy = [...arr];  // [1, 2, 3](新数组,不影响原数组)

🔹 3. 传参给函数

javascript 复制代码
function sum(a, b, c) {
    return a + b + c;
}

let nums = [1, 2, 3];
sum(...nums);  // 等同于 sum(1, 2, 3) → 6

📊 总结

写法 含义 能用吗?
Math.min(arr) 传一个数组进去 NaN
Math.min(...arr) 把数组拆开成独立元素 ✅ 正确
Math.min(...arr.map(Number)) 先转数字,再拆开 ✅✅ 最推荐

💡 记忆口诀

... = "拆开!"

把数组 [1, 2, 3] 拆成 1, 2, 3

没有 ... 就是把整个数组当一个东西扔进去,函数不认识 😂

相关推荐
学Linux的语莫3 分钟前
Vue 3 入门教程
前端·javascript·vue.js
怕浪猫30 分钟前
第一章、Chrome DevTools Protocol (CDP) 详解
前端·javascript·chrome
小小编程路39 分钟前
C++ 异常 完整讲解
开发语言·c++
AI科技星1 小时前
数术工坊 · 第四卷 橡皮泥江湖(拓扑学)【完整定稿】
c语言·开发语言·汇编·electron·概率论·拓扑学
张忠琳1 小时前
【Go 1.26.4】Golang Select 深度解析
开发语言·后端·golang
AC赳赳老秦3 小时前
OpenClaw+Power Apps 实战:自动生成 Power Apps 应用、连接 Excel 数据源
大数据·开发语言·python·serverless·excel·deepseek·openclaw
提笔了无痕3 小时前
如何用Go实现整套RAG流程
开发语言·后端·golang
(Charon)3 小时前
【C++ 面试高频基础:指针、引用、const、static、new/delete 总结】
java·开发语言
Yeats_Liao3 小时前
Feed流系统设计(三):数据模型与存储设计,从表结构到Redis收件箱
java·javascript·redis
我是真菜3 小时前
彻底理解js中的深浅拷贝
前端·javascript