乐趣区

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

退出移动版