freeCodeCamp/curriculum/challenges/chinese/02-javascript-algorithms-an.../object-oriented-programming/reset-an-inherited-construc...

1.9 KiB

id title challengeType forumTopicId dashedName
587d7db1367417b2b2512b86 重置一个继承的构造函数属性 1 301324 reset-an-inherited-constructor-property

--description--

当一个对象从另一个对象那里继承了其 prototype 时,那它也继承了父类的 constructor 属性。

请看下面的举例:

function Bird() { }
Bird.prototype = Object.create(Animal.prototype);
let duck = new Bird();
duck.constructor

但是 duck 和其他所有 Bird 的实例都应该表明它们是由 Bird 创建的,而不是由 Animal 创建的。 为此,你可以手动把 Bird's 的 constructor 属性设置为 Bird 对象:

Bird.prototype.constructor = Bird;
duck.constructor

--instructions--

修改你的代码,使得 duck.constructorbeagle.constructor 返回各自的构造函数。

--hints--

Bird.prototype 应该是 Animal 的一个实例。

assert(Animal.prototype.isPrototypeOf(Bird.prototype));

duck.constructor 应该返回 Bird

assert(duck.constructor === Bird);

Dog.prototype 应该是 Animal 的一个实例。

assert(Animal.prototype.isPrototypeOf(Dog.prototype));

beagle.constructor 应该返回 Dog

assert(beagle.constructor === Dog);

--seed--

--seed-contents--

function Animal() { }
function Bird() { }
function Dog() { }

Bird.prototype = Object.create(Animal.prototype);
Dog.prototype = Object.create(Animal.prototype);

// Only change code below this line



let duck = new Bird();
let beagle = new Dog();

--solutions--

function Animal() { }
function Bird() { }
function Dog() { }
Bird.prototype = Object.create(Animal.prototype);
Dog.prototype = Object.create(Animal.prototype);
Dog.prototype.constructor = Dog;
Bird.prototype.constructor = Bird;
let duck = new Bird();
let beagle = new Dog();