Большое уважение к вам, Чаббард. :)
Ваш пример очень помог.
Мой оригинальный «пример» был довольно легкомысленным. : P
Хотя я все еще сталкиваюсь с несколькими проблемами ...
Чтобы подробно остановиться на моем образце «кошка» (максимально кратко):
function mammal(){
// 'mammals' constructor - My 'empirical' 'class'...
}
mammal.count = 0; // To keep track of the zoo I've created. No subclass can access this property. It's a 'static' property
// I could have declared this 'method' inside of my constructor
// with an anonymous function attached to (this.prototype.breathe).
mammal.track = function (){
this.count++;
}
mammal.prototype.breathe = function(){
alert("Inhale... Exhale...");
}
function cat(){
// 'cat' constructor
}
// All cats shall now become a type of mammal
cat.prototype = new mammal();
cat.prototype = function(){
// This anonymous function is the REAL constructor for my 'cat' 'superclass'
}
cat.prototype.meow = function(){
alert("Meow!");
}
function lion(){
// The king of jungle...
// I can keep track of the number of 'mammal' instances I create here
mammal.track();
}
// All lions are cats, afterall...
lion.prototype = new cat();
// Also note that I have no plans to extend the lion class.
// I have no need of a class below the 'idea' of a lion
lion.name = "Kitty"; // :}
// Here's where I get confused...
// I can set (lion.name) via instances, can't call (lion.pounce), but (lion.prototype.roar) works all day long! o_0
lion.pounce = function(){
alert(this.name+" pounces...")
}
lion.prototype.roar = function(){
alert(this.name+" doesn't meow, he ROOOAAARS!");
}
// With these constructs in place, I can now script...
$(document).ready(function(){
var rory = new lion();
var napoleon = new lion();
alert("We have "+mammal.count+" mammals running about");
// This is 'Rory'...
rory.name = 'Rory'; // Respect the pun...
rory.roar();
// This is 'Napoleon'...
napoleon.name = 'Napoleon';
napoleon.breathe(); // Napoleon can't breathe... he didn't inherit mammal.prototype.breathe(), for some reason
napoleon.roar(); // How am I able to set (lion.name), but not call lion.pounce()?
napoleon.pounce();
});
Вы, конечно, были правы, каждый класс в моей цепочке вплоть до создания конечного (ых) экземпляра (ов) является функцией-прототипом. Но почему (lion.name) работает, а не (lion.prototype.name). И наоборот, почему lion.prototype.pounce () может работать, когда lion.pounce () не работает?
Наполеон и Рори, в конце концов, оба Львы ...
У меня много вопросов по Javascript ... Это очень странный язык ...;)