JavaScript 展开运算符详解

什么是展开运算符?
展开运算符 ...item 的作用是将对象 item 的所有属性"展开"为一个新对象,从而在不修改原对象的前提下,创建一个包含其所有属性的新对象。这种用法在 JavaScript 中非常常见,尤其是在处理对象和数组时。
1. 展开对象的属性
当使用 ...item 时,JavaScript 会将 item 对象的所有可枚举属性复制到新对象中。例如,如果 item 是 { a: 1, b: 2 },那么 ...item 会生成一个新对象 { a: 1, b: 2 }。这种用法可以避免手动复制属性,使代码更简洁。

const item = { a: 1, b: 2 };
const newItem = { ...item };
console.log(newItem); // { a: 1, b: 2 }

2. 合并对象
展开运算符常用于合并多个对象。例如,你可以将多个对象的属性合并到一个新对象中:

const obj1 = { a: 1 };
const obj2 = { b: 2 };
const merged = { ...obj1, ...obj2 };
console.log(merged); // { a: 1, b: 2 }

在这个例子中,...obj1...obj2 依次将 obj1obj2 的属性合并到新对象中。

3. 在数组方法中使用
展开运算符也可以用于数组方法,例如 map、filter、reduce 等。在这些场景中,...item 通常用于创建一个新数组,其中包含对原数组元素的修改或扩展。例如:

const list = [
  { date: '2023-10-01', checked: false },
  { date: '2023-10-02', checked: false }
];

const dayList = list.map(item => ({
  ...item,
  checked: this.dateDay === item.date
}));

在这个例子中,...item 用于复制 item 对象的所有属性,并添加一个新的 checked 属性,该属性的值取决于 item.date 是否等于 this.dateDay。这种方式可以避免直接修改原数组,而是返回一个新的数组。

  1. 函数参数展开
    在函数调用中,展开运算符可以将数组或对象展开为独立的参数。例如:
function add(a, b, c) {
  console.log(a + b + c);
}

const numbers = [1, 2, 3];
add(...numbers); // 等价于 add(1, 2, 3)

在这个例子中,...numbers 将数组 numbers 展开为三个独立的参数,传递给 add 函数。

  1. 解构赋值
    展开运算符还可以用于解构赋值,从对象或数组中提取值。例如:
const person = { name: 'Alice', age: 30 };
const { name, ...rest } = person;
console.log(name); // 输出: Alice
console.log(rest); // 输出: { age: 30 }

在这个例子中,...rest 用于将 person 对象中除了 name 之外的所有属性提取到 rest 对象中。

总结
展开运算符 ...JavaScript 中非常强大的工具,它不仅可以用于对象和数组的合并,还可以用于函数调用、解构赋值等多种场景。通过合理使用展开运算符,可以简化代码,提高代码的可读性和可维护性。

https://metaso.cn/s/mSR6yYK

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值