Diskuze: this vs prototype
V předchozím kvízu, Online test znalostí JavaScript, jsme si ověřili nabyté zkušenosti z kurzu.
Zobrazeno 3 zpráv z 3.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí JavaScript, jsme si ověřili nabyté zkušenosti z kurzu.
Ahoj třídy se v js deklarují přes prototype, protože tak je js navržen. Díky prototype můžeš upravovat/přidávat metody v instancích, můžeš dědit, funguje ti operátor instanceof, prototype je efektivnější.
Deklarace třídy by měla vypadat takto:
var two = function(number)
{
this.number = number;
};
two.prototype.getNumber = function()
{
return this.number;
};
Privátní proměnné vlastně neexistují. "var number" je lokální proměnná. Nesnaž se v js vytvořit nějaké ultimátní zapouzdření. Proměnné pro celou třídu přiřazuj do this.
Příjde mi, že je docela zmatek kolem oop v js. Tohle téma popsal pěkně
Daniel Steigerwald, určitě stojí za přečtění
http://www.zdrojak.cz/…vascriptu-i/
Když to trochu zjednoduším - To, co je definováno v kontruktoru je unikátní pro všechny třídy (vytváří se pro každou instance a vzhledem k tomu že funkce je vlastně třída, potom i funkce). To, co je definováno v prototype je společný pro všechny třídy (a tedy se vytváří pouze jednou). Ovšem když přiřadíš třídě proměnnou se stejným názvem, tak se nepřepíše prototype ale změna se zapíše přímo do třídy (nepřepíše se prototyp).
function A()
{
this.a=1;
}
A.prototype.b=2;
A.prototype.fun = function()
{
console.log(this.b);
};
var first=new A();
var second=new A();
// first.a=1, first.b=2, second.a=1, second.b=2
first.b=3;
// first.a=1, first.b=3, first.prototype.b=2, second.a=2, second.b=2
first.fun(); //output 3
Zobrazeno 3 zpráv z 3.