废话不多说,直接上代码:
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__
指向原对象。