ES6中对象的扩展运算符使用问题?

let o1 = { a: 1 };
let o2 = { b: 2 };
o2.__proto__ = o1;
let o3 = { ...o2 };
对象o3是o2的拷贝,但是只复制了o2自身的属性,没有复制它的原型对象o1的属性,这段代码中let o3 = { ...o2 };这句赋值语句跟let o3 = o2有什么区别?
阅读 7.2k
4 个回答

... 的意义就是 Object Spread Operator对象展开运算符

通过babel转换的话,会转换成Object.assign
所以,let o3 = { ...o2 },最终等价的是:let o3 = { b: 2 };
let o4 = o2 的话,就是引用,修改其中一个对象,另一个也会变。

let o4 = o2;

o3 === o2 //false
o4 === o2 //true

对象是引用类型。赋值是指向指针,所以o4和o2引用同一个对象。

拷贝是新开一块内存,不指向同一个对象。

纠正下题目 es7并不是es6 这个相当于Object.assign({},o2)

这个玩应用到数组里比较好,别用来结构对象什么的了,用不好就乱七八糟的了。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题