在JavaScript中,扩展运算符(...)和剩余参数(也是用 ... 表示)是紧密相关但用途不同的两个概念。以下为你详细解析,方便面试作答:
1. 扩展运算符
- 定义与外观 :扩展运算符(
...)用于在函数调用、数组字面量或对象字面量中展开数组或对象的元素或属性。 - 在数组中的应用 :
- 数组展开 :将数组展开成独立元素,常用于函数调用场景。例如,
Math.min()函数接收多个数字参数并返回最小值,若已有数字数组,可借助扩展运算符实现功能。
- 数组展开 :将数组展开成独立元素,常用于函数调用场景。例如,
javascript
let numbers = [3, 5, 1];
let minNumber = Math.min(...numbers);
console.log(minNumber);
这里 ...numbers 将数组 numbers 展开为 3, 5, 1,作为 Math.min() 的参数,如同直接传递这些数字。 - 数组合并:简洁地合并多个数组。
javascript
let arr1 = [1, 2];
let arr2 = [3, 4];
let combinedArray = [...arr1, ...arr2];
console.log(combinedArray);
通过 ...arr1 和 ...arr2,将两个数组合并为 [1, 2, 3, 4],相比 concat() 方法,代码更简洁,合并多个数组时优势明显。 - 数组复制:实现数组浅拷贝。
javascript
let originalArray = [1, 2, 3];
let copiedArray = [...originalArray];
console.log(copiedArray);
copiedArray 是 originalArray 的浅拷贝,两个数组内容相同但内存独立,修改其中一个不影响另一个。
- 在对象中的应用 :
- 对象展开:在对象字面量中展开对象的可枚举属性。
javascript
let obj1 = { a: 1, b: 2 };
let obj2 = { ...obj1, c: 3 };
console.log(obj2);
...obj1 将 obj1 的属性 a 和 b 展开到 obj2 中,再添加新属性 c,最终 obj2 为 { a: 1, b: 2, c: 3 }。 - 对象合并:合并多个对象。
javascript
let objA = { x: 10 };
let objB = { y: 20 };
let mergedObj = { ...objA, ...objB };
console.log(mergedObj);
mergedObj 合并了 objA 和 objB 的属性,若有相同属性名,后面对象的属性会覆盖前面对象的属性。
2. 剩余参数
- 定义与外观 :剩余参数(
...)用于在函数定义中收集多余的参数到一个数组中。 - 应用场景 :
- 处理不定数量参数:在函数定义时,不确定会传入多少参数的情况下非常有用。例如实现一个求和函数,可处理任意数量参数。
javascript
function sum(...nums) {
return nums.reduce((acc, num) => acc + num, 0);
}
let result = sum(1, 2, 3);
console.log(result);
这里 ...nums 收集了所有传递给 sum() 函数的参数,无论参数个数,都能方便处理。与 arguments 对象相比,剩余参数是真正的数组,具备数组的方法,使用更便捷直观。 - 函数参数解构:在函数参数解构时,剩余参数可收集未匹配的参数。
javascript
function showArgs([a, b,...rest]) {
console.log(a);
console.log(b);
console.log(rest);
}
showArgs([1, 2, 3, 4]);
在这个例子中,a 匹配数组第一个元素 1,b 匹配第二个元素 2,...rest 收集剩余元素 [3, 4]。
3. 两者区别
- 使用位置:扩展运算符用于函数调用、数组字面量和对象字面量中,展开数组或对象;剩余参数仅用于函数定义的参数列表中,收集多余参数。
- 功能侧重:扩展运算符主要是将已有数据结构展开,方便操作;剩余参数则专注于收集函数调用时传入的多余参数,便于在函数内统一处理。