并不是的。
根据你的实际需要,一个 可能性 可能是集
o作为一个新的对象的原型。
var o = {};(function(x){ var obj = Object.create( x ); obj.foo = 'foo'; obj.bar = 'bar';})(o);alert( o.foo ); // undefined因此,您添加到的任何属性
obj都不会添加到中
o。
obj使用与中的属性相同的属性名称添加到的任何属性
o都将阴影该
o属性。
当然,如果没有阴影,添加到的任何属性
o都将可用
obj,并且
o原型链中所有对象的更新都将相同
o。
另外,如果
obj具有引用另一个对象的属性(例如Array),则需要确保在将该对象添加到对象之前将其遮蔽,否则,这些成员将添加到中
obj,并将在所有对象之间共享有
obj原型链。
var o = { baz: []};(function(x){ var obj = Object.create( x ); obj.baz.push( 'new value' );})(o);alert( o.baz[0] ); // 'new_value'在这里您可以看到,因为您没有使用
bazon
o的
baz属性将on 遮蔽在Array 上
obj,所以
o.bazArray被修改了。
因此,您需要先对其进行阴影处理:
var o = { baz: []};(function(x){ var obj = Object.create( x ); obj.baz = []; obj.baz.push( 'new value' );})(o);alert( o.baz[0] ); // undefined


