Heim > Web-Frontend > js-Tutorial > Ein einfaches Verständnis der Klassen in es6 (mit Beispielen)

Ein einfaches Verständnis der Klassen in es6 (mit Beispielen)

不言
Freigeben: 2018-10-25 15:43:33
nach vorne
1831 Leute haben es durchsucht

Dieser Artikel vermittelt Ihnen ein einfaches Verständnis der Klassen in es6 (mit Beispielen). Freunde in Not können sich darauf beziehen.

Klassenklasse

Grundlegende Konzepte, aufgezeichnet, damit Sie Ihr Verständnis später vertiefen können

Verstehen Sie, was eine Klasse ist

Was ist Unterricht? Sie könnten genauso gut einen schreiben und einen Blick auf den Prototyp von

class Demo {
    constructor() {
        this.a = 1;
        this.b = this.f;
    }
    f() {
        return this;
    }
}
Demo.prototype; //{
                //  constructor: class Demo
                //  f: ƒ f()           
                //  __proto__: Object }
Nach dem Login kopieren

Demo werfen. Sie können sehen, dass diese drei Attribute nicht überquerbar sind und es im Vergleich zur Demo-Klasse eine weitere __proto__-Prototypkette gibt. Werfen wir einen Blick auf eine neue Demo

let o = new Demo();
console.log(Object.getPrototypeOf(o));  //{
                                        //  constructor: class Demo
                                        //  f: ƒ f()           
                                        //  __proto__: Object }
Nach dem Login kopieren

Tatsächlich entspricht die Demo-Klasse dem Prototyp der Demo-Instanz

Der Konstruktor in der Klasse

Meiner Meinung nach

    constructor() {
        this.a = 1;
        this.b = this.f;
    }
Nach dem Login kopieren

Dieser Teil entspricht der Funktion des Konstruktors in es5. Im Prozess von new wird diesem ein Wert zugewiesen und dieser wird zurückgegeben, um ein Instanzobjekt zu werden.
Wenn Sie also ein Objekt zurückgeben im Konstruktor und es ist nicht gleich null, dann das Instanzobjekt Es ist der Rückgabewert, der den gleichen Effekt hat wie der es5-Konstruktor

Methode in der Klasse

    f() {
        return this;
    }
Nach dem Login kopieren

Diese Methode letztendlich gehört zur Prototypenkette des InstanzobjektsNicht durchquerbare MethodeDaher kann es auch von Instanzobjekten verwendet werden

Neuer Wissenspunkt

Die statische Methode der Klasse

bedeutet, dass die Methode nicht von der Instanz geerbt wird, sondern direkt über die Klasse aufgerufen wird

class Demo {
    constructor() {
        this.a = this;
        this.b = this.f;
    }
    static g() {
        return this;
    }
    static f() {
        return this;
    }
}
let o = new Demo(); 
//console.log(o.b());    //not a function
//console.log(o.g());     //not a function
Demo.g() === Demo;        //true
Nach dem Login kopieren

Dies zeigt in der statischen Methode auf die Klasse selbst, während this.a = this auf zeigt das Instanzobjekt selbst

Statische Methoden können von Unterklassen geerbt werden

class Foo {
  static classMethod() {
    return 'hello';
  }
}

class Bar extends Foo {
}

Bar.classMethod() // 'hello'
Nach dem Login kopieren

Statische Methoden können vom Superobjekt aufgerufen werden

class Foo {
  static classMethod() {
    return 'hello';
  }
}

class Bar extends Foo {
  static classMethod() {
    return super.classMethod() + ', too';
  }
}

Bar.classMethod() // "hello, too"
Nach dem Login kopieren

Die Klasse enthält nur statische Methoden, keine statischen Attribute

Sofortige Ausführung von Klassenausdrücken

var o =  new class {
    constructor(n) {
        this.a = n;
        this.b = this.f;
    }
    g() {
        return n;
    }
    f() {
        return this;
    }

}(1)

o.a;             // 1
Nach dem Login kopieren

Es gibt keine Variablenheraufstufung in der Klassendeklaration

new Das .target-Attribut

gibt nach new For ein Objekt zurück Beispielsweise gibt der Konstruktor f in es5 durch den neuen Aufruf nicht undefiniert zurück, sondern durch den neuen Aufruf den Konstruktor selbst

function f() {
    return new.target;
}
console.log((new f()) === f);       //true
Nach dem Login kopieren

. Geben Sie dann die Klasse selbst zurück. Dies ist das Gleiche wie bei der statischen Methode; new gibt welche Klasse

class Shape {
  constructor() {
    if (new.target === Shape) {
      throw new Error('本类不能实例化');
    }
  }
}

class Rectangle extends Shape {
  constructor(length, width) {
    super();
    // ...
  }
}

var x = new Shape();  // 报错
var y = new Rectangle(3, 4);  // 正确
Nach dem Login kopieren

zurück

Das obige ist der detaillierte Inhalt vonEin einfaches Verständnis der Klassen in es6 (mit Beispielen). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:segmentfault.com
Erklärung dieser Website
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage