JavaScript中的Objectcreate的模拟实现

废话不多说,直接上代码:

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__指向原对象。

评论

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

这个站点使用 Akismet 来减少垃圾评论。了解你的评论数据如何被处理