Heim >Web-Frontend >js-Tutorial >Detaillierte Erklärung des Prototyps in JS

Detaillierte Erklärung des Prototyps in JS

不言
不言Original
2018-07-14 17:48:201654Durchsuche

Dieser Artikel stellt hauptsächlich die detaillierte Erklärung des Prototyps in JS vor, die einen gewissen Referenzwert hat. Jetzt können Freunde in Not darauf verweisen.

Der Fototyp in JS ist der Vergleich in JS . Ein schwer zu verstehender Teil

Dieser Artikel basiert auf den folgenden Wissenspunkten:

1 Prototyp-Designmuster

Sie können clone( in verwenden .Net ), um die Prototyp-Methode zu implementieren

Die Hauptidee der Prototyp-Methode ist, dass es jetzt eine Klasse A gibt und ich eine Klasse B erstellen möchte. Diese Klasse wird mit A prototypisiert und kann sein erweitert. Wir nennen den Prototyp von B A.

2 JavaScript-Methoden können in drei Kategorien unterteilt werden:

eine Klassenmethode

b Objektmethode

c Prototypmethode

Beispiel:

function People(name)
{
  this.name=name;
  //对象方法
  this.Introduce=function(){
    alert("My name is "+this.name);
  }
}
//类方法
People.Run=function(){
  alert("I can run");
}
//原型方法
People.prototype.IntroduceChinese=function(){
  alert("我的名字是"+this.name);
}

 

//测试

var p1=new People("Windking");

p1.Introduce();

People.Run();

p1.IntroduceChinese();

3 obj1.func.call(obj)-Methode

bedeutet, obj als obj1 zu behandeln und die func-Methode aufzurufen

Okay, lass uns die Fragen einzeln lösen:

Was bedeutet Prototyp?

Jedes Objekt in JavaScript hat ein Prototypattribut. Die Erklärung des Prototypattributs eines Objekts in Javascript lautet: Gibt einen Verweis auf den Prototyp des Objekttyps zurück.

A.prototype = new B();

Das Verständnis von Prototypen sollte nicht mit Vererbung verwechselt werden. Der Prototyp von A ist eine Instanz von B. Es versteht sich, dass A alle Methoden und Eigenschaften in B geklont hat. A kann die Methoden und Eigenschaften von B verwenden. Der Schwerpunkt liegt hier eher auf dem Klonen als auf der Vererbung. Diese Situation kann auftreten: Der Prototyp von A ist eine Instanz von B und der Prototyp von B ist auch eine Instanz von A.

Schauen wir uns zunächst ein experimentelles Beispiel an:

function baseClass()
{
  this.showMsg = function()
  {
     alert("baseClass::showMsg");   
  }
}

function extendClass()
{
}

extendClass.prototype = new baseClass();
var instance = new extendClass();
instance.showMsg(); // 显示baseClass::showMsg

Wir definieren zuerst die BaseClass-Klasse und müssen dann ExtentClass definieren, aber wir planen, eine Instanz von BaseClass als Prototyp zu verwenden, und Die zu klonende ExtendClass enthält auch die Objektmethode showMsg.

extendClass.prototype = new baseClass() kann wie folgt gelesen werden: „extendClass“ wird erstellt, indem eine Instanz von „baseClass“ als Prototyp geklont wird.

Dann wird es eine Frage geben: Was passiert, wenn extensionClass selbst eine Methode mit demselben Namen wie die Methode von baseClass enthält?

Das Folgende ist erweitertes Experiment 2:

function baseClass()
{
    this.showMsg = function()
    {
        alert("baseClass::showMsg");   
    }
}

function extendClass()
{
    this.showMsg =function ()
    {
        alert("extendClass::showMsg");
    }
}

extendClass.prototype = new baseClass();
var instance = new extendClass();

instance.showMsg();//显示extendClass::showMsg

Das Experiment beweist: Wenn die Funktion ausgeführt wird, geht sie zuerst zur Funktion der Ontologie, um sie zu finden gefunden, wird es ausgeführt. Wenn es nicht gefunden werden kann, wird es zur Prototyp-Suchfunktion weitergeleitet. Oder es kann verstanden werden, dass der Prototyp die Funktion mit demselben Namen nicht klont.

Dann wird es eine neue Frage geben:

Was ist, wenn ich eine Instanz von extensionClass verwenden möchte, um die Objektmethode showMsg von baseClass aufzurufen?

Die Antwort ist, dass Sie call:

extendClass.prototype = new baseClass();
var instance = new extendClass();


var baseinstance = new baseClass();
baseinstance.showMsg.call(instance);//显示baseClass::showMsg

baseinstance.showMsg.call(instance); verwenden können, hier lautet „Instanz als Basisinstanz aufrufen und ihre Objektmethode showMsg aufrufen“

Okay, hier könnte jemand fragen, warum nicht baseClass.showMsg.call(instance);

Das ist der Unterschied zwischen Objektmethoden und Klassenmethoden. Was wir aufrufen möchten, ist das Objekt baseClass-Methode

Wenn Sie schließlich den folgenden Code klar verstehen, können Sie verstehen, was dieser Artikel sagt:

<script type="text/javascript">

function baseClass()
{
    this.showMsg = function()
    {
        alert("baseClass::showMsg");   
    }
   
    this.baseShowMsg = function()
    {
        alert("baseClass::baseShowMsg");
    }
}
baseClass.showMsg = function()
{
    alert("baseClass::showMsg static");
}

function extendClass()
{
    this.showMsg =function ()
    {
        alert("extendClass::showMsg");
    }
}
extendClass.showMsg = function()
{
    alert("extendClass::showMsg static")
}

extendClass.prototype = new baseClass();
var instance = new extendClass();

instance.showMsg(); //显示extendClass::showMsg
instance.baseShowMsg(); //显示baseClass::baseShowMsg
instance.showMsg(); //显示extendClass::showMsg

baseClass.showMsg.call(instance);//显示baseClass::showMsg static

var baseinstance = new baseClass();
baseinstance.showMsg.call(instance);//显示baseClass::showMsg

</script>

Das Obige ist der gesamte Inhalt dieses Artikels. Ich hoffe, dass es für alle hilfreich sein wird. Weitere verwandte Inhalte finden Sie auf der chinesischen PHP-Website!

Verwandte Empfehlungen:

Analyse von Funktionsdeklarationen und Funktionsausdrücken in js

So konvertieren Sie Pseudo-Arrays über js Für Array

Das obige ist der detaillierte Inhalt vonDetaillierte Erklärung des Prototyps in JS. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn