JavaScript中的Object.create的模拟实现
废话不多说,直接上代码:
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__指向原对象。
本文内容仅供个人学习/研究/参考使用,不构成任何决策建议或专业指导。分享/转载时请标明原文来源,同时请勿将内容用于商业售卖、虚假宣传等非学习用途哦~感谢您的理解与支持!