废话不多说,直接上代码:
function createObj(o) {
function F() {}
F.prototype = o;
return new F();
}
看看栗子:
const person = {
name: 'willem',
colors: ['red', 'green', 'blue']
};
const p1 = createObj(person);
const p2 = createObj(person);
p1.colors.push('white');
console.log(person, p1, p2);
不难看出来,其实Object.create只是对对象的一个浅复制,在修改引用类型的属性时,所有属性都会被修改。这是由于Object.create的实现机制,只是利用new,相当于是在中间加了一个中间层,从图中也可以看到,多了一个__proto__
指向原对象。
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。