JavaScript对象展开操作符 ...
对象展开操作符(Spread Operator)...
在JavaScript(特别是在ES6及以后的版本中)中是一个强大的工具,它允许你将一个对象的所有可枚举属性复制到另一个对象中。以下是关于对象展开操作符的一些详细信息和用法:
1. 合并对象
对象展开操作符可以将一个或多个对象的属性合并到一个新的对象中。如果多个对象具有相同的属性,则后面的对象会覆盖前面的对象中的属性。
1 2 3 | const obj1 = {a: 1, b: 2}; const obj2 = {b: 3, c: 4}; const merged = {...obj1, ...obj2}; // {a: 1, b: 3, c: 4} |
在这个例子中,obj1
和 obj2
的属性被合并到了 merged
对象中。由于 obj1
和 obj2
都包含 b
属性,所以 merged
对象中的 b
属性值是 obj2
中的 b
属性值(即3)。
2. 创建新对象
对象展开操作符也可以用于创建一个新的对象,并将一个或多个对象的属性复制到新对象中
1 2 | const obj1 = {foo: 'foo' , bar: 'bar' }; const newObj = {...obj1, baz: 'baz' }; // {foo: 'foo', bar: 'bar', baz: 'baz'} |
在这个例子中,newObj
是一个新的对象,它包含了 obj1
的所有属性和一个额外的 baz
属性。
3. 复制对象
对象展开操作符也可以用于快速复制一个对象。但是要注意,这是一个浅拷贝(shallow copy),意味着如果对象的属性值是引用类型(如数组或另一个对象),那么复制的将是引用而不是实际的数据。
1 2 | const obj = {a: 1, b: [2, 3]}; const copy = {...obj}; // {a: 1, b: [2, 3]} |
虽然 copy
看上去和 obj
一样,但它们的 b
属性实际上指向的是同一个数组。对 copy.b
的修改也会影响 obj.b
。
4. 注意事项
- 如果尝试展开一个非对象(如数字、字符串、
null
、undefined
等),则会自动将其转换为对象(对于数字和字符串,它们会被转换为一个类似数组的对象,其索引为字符的Unicode码点),但通常这不是你想要的结果。 - 对象展开操作符不会展开对象中的对象属性,也就是说,如果对象的属性值是一个对象,那么这个子对象不会被展开。
对象展开操作符为处理JavaScript对象提供了极大的便利,使代码更加简洁和易读。
分类:
js、html、css
标签:
javascript
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· .NET10 - 预览版1新功能体验(一)