Misleading goal in Javascript Algorithms and Data Structures Certification

Misleading goal in Javascript Algorithms and Data Structures Certification
0
#1

Exercise “Add methods After Inheritance” in the Object Oriented Programming section asks for Dog to have its own property “bark”, but what it really wants is for Dog.prototype to have its own property “bark”. Trying to put the property “bark” on Dog will not help to pass the exercise.

#2

the instructions are

Add all necessary code so the Dog object inherits from Animal and the Dog's prototype constructor is set to Dog. Then add a bark() method to the Dog object so that beagle can both eat() and bark() . The bark() method should print “Woof!” to the console.

As you can’t type inside the constructor Dog function (there are the comments that tell you where to write) you need to create the new method using the prototype keyword, and that is adding a property to the Dog object.

Object Oriented Programming is a difficult subject, it needs a lot to learn the basics well - not surrender now!

#3

Thanks for responding! My issue is the wording of this goal. saying that it should be an “own” property made me test with

console.log(Dog.hasOwnProperty("bark"));

which returns true if you do Dog.bark = function(){... but not if you attach bark to Dog’s prototype. The goal should be reworded to reflect this.

#4

If you check the documentation about hasOwnProperty()

All descendents of Object inherit the hasOwnProperty method. This method can be used to determine whether an object has the specified property as a direct property of that object; unlike the in operator, this method does not check for a property in the object’s prototype chain.

Try with the in operator mentioned above

#5

I understand this, however it still doesn’t make bark an “own” property. See the ECMAScript 2018 specification for own properties, and below it, inherited properties. It says that properties of prototypes should be considered “inherited”, not “own”. I can’t post the link here, but googling ECMAScript 2018 Language Specification should bring you there.