我做了一個快速搜索,但似乎無法找到這個問題的答案,只是指繼承時複製函數原型。 爲什麼不將屬性添加到構造函數原型obj中,而不是使用this關鍵字。我確信有一個理由不會,但我想更好地理解JavaScript的細微差別。例如在正常的原型繼承中,你會「this」。原型繼承和原型對象,爲什麼不用這個程度?
function Dog(name,age,breed){
this.name=name;
this.age=age;
this.breed=breed;
}
Dog.prototype.bark=function(){console.log("bark bark bark");}
let spike=new Dog("Spike",6,"lab");
let rover=new Dog("Rover",8,"poodle");
//^with the constructor function, no instance has the bark function but
//but refers to the same function on the constructor prototype obj, so the
//same function isn't being duplicated. However new keyword changes the
//context of this to refer to the obj so these properties are duplicated
//on every instance.
//I'm curious as to the reason why new doesn't change this to refer to the
//prototype obj for example and then have the instance refers its
//constructor's prototype like with the bark function?
//for example why isn't this a common pattern and what are the reasons I
//should use it.
function Dog(name,age,breed){
Dog.prototype.name=name;
Dog.prototype.age=age;
Dog.prototype.breed=breed;
}
let spike=new Dog("Spike",6,"lab");
let rover=new Dog("rover",8,"poodle");
//I feel like the above code would be more DRY, I'm sure there is a reason
// this isn't common and I'm curious as to why
看看'spike.name'是什麼時候你做你的方式,你會明白爲什麼人們不這樣做你的方式。 – user2357112