Heim >Web-Frontend >js-Tutorial >JavaScript-Konstruktor erstellt Objekte (Zusammenfassungsfreigabe)

JavaScript-Konstruktor erstellt Objekte (Zusammenfassungsfreigabe)

WBOY
WBOYnach vorne
2022-08-04 10:16:452882Durchsuche

Dieser Artikel vermittelt Ihnen relevantes Wissen über Javascript, das hauptsächlich Probleme im Zusammenhang mit der Erstellung von Objekten durch JavaScript-Konstruktoren behandelt. Konstruktoren werden auch als Konstruktoren und Typfunktionen bezeichnet, und ihre Funktionen ähneln Objektvorlagen. Ein Konstruktor kann eine beliebige Zahl generieren von Instanzen haben die gleichen Attribute und Verhaltensmerkmale, sind aber nicht gleich. Ich hoffe, dass es für alle hilfreich ist.

JavaScript-Konstruktor erstellt Objekte (Zusammenfassungsfreigabe)

[Verwandte Empfehlungen: Javascript-Video-Tutorial, Web-Frontend]

Was ist ein Konstruktor?

JavaScript-Konstruktor (Konstruktor) wird auch als Konstruktor und Typfunktion bezeichnet und hat eine ähnliche Funktion Zu einer Objektvorlage kann eine Konstruktorfunktion eine beliebige Anzahl von Instanzen generieren. Die Instanzobjekte haben die gleichen Attribute und Verhaltensmerkmale, sind jedoch nicht gleich.
Verwenden Sie Konstruktoren, um Objekte verschiedener Klassen zu erstellen.

Erstellung eines Konstruktors

Der Konstruktor ist eine gewöhnliche Funktion. Es gibt keinen Unterschied zwischen der Erstellungsmethode und gewöhnlichen Funktionen. Der Unterschied zwischen Konstruktoren und gewöhnlichen Funktionen besteht in der Aufrufmethode Direkt Der Konstruktor muss das Schlüsselwort new verwenden, um

dieses Zeigeproblem

drei Formen dieser Zeigesituation aufzurufen. Wenn es als Funktion aufgerufen wird, ist dies das Fenster
    Der Ausführungsablauf des Konstruktors
  • Erstellen Sie sofort ein neues Objekt

Setzen Sie das neue Objekt in der Funktion auf this, und Sie können dies im Konstruktor verwenden, um auf das neue Objekt zu verweisen (d. h. dies zeigt auf). neu erstelltes Objekt)

  • Führen Sie den Code in der Funktion Zeile für Zeile aus

  • Gib das neu erstellte Objekt als Rückgabewert zurück

Ein mit demselben Konstruktor erstelltes Objekt wird als Klassenobjekt bezeichnet. Ein Konstruktor wird auch als Klasse bezeichnet. Wir nennen das durch einen Konstruktor erstellte Objekt eine Instanz dieser Klasse. Was das oben Gesagte betrifft, ist Obj eine Klasse und obj eine Instanz der Klasse Obj.

Konstruktor-Instanz
  • Erstellen Sie zwei Klassen, eine Personenklasse und eine Hundeklasse.

    nbsp;html>
        <meta>
        <meta>
        <meta>
        <title>Document</title>
        <script>
            //构造一个创建人的类
            function Person(name , age , gender){
                console.log(&#39;指向:&#39;,this);
                this.name = name;
                this.age = age ;
                this.gender = gender;
                this.sayName = function(){
                    console.log(this.name)
                }
            }
    
            //构造一个创建狗的类
            function Dog(name , age ){
                console.log(&#39;指向:&#39;,this);
                this.name = name;
                this.age = age ;
                this.sayHello = function(){
                    console.log(&#39;汪汪汪~~&#39;);
                }
            }
    
            //创建一个人的实例
            var per = new Person(&#39;苏凉&#39;,21,&#39;男&#39;);
            console.log(per);
            per.sayName();
    
            //创建一个狗的实例
            var dog = new Dog(&#39;旺财&#39;,5);
            console.log(dog);
            dog.sayHello();
        </script>
        
    Laufendes Ergebnis:
  • Der Vorteil des Konstruktors besteht darin, dass wir viele verschiedene Objekte unterscheiden können, d Objekte erstellen Es ist unmöglich, die Objekttypen zu unterscheiden, sie gehören alle zu einer großen Kategorie (Objekt).
  • Instanceof-Schlüsselwort

  • Verwenden Sie „Instanceof“, um zu überprüfen, ob ein Objekt eine Instanz einer Klasse ist
  • Syntax:

JavaScript-Konstruktor erstellt Objekte (Zusammenfassungsfreigabe)Wenn ja, geben Sie „true“ zurück, andernfalls geben Sie „false“ zurück.

  console.log(dog instanceof Dog); //true
  console.log(dog instanceof Person); //false
  console.log(dog instanceof Object); //true

Alle Objekte sind Nachkommen von Object, also von jedem Objekt gibt true zurück, wenn eine Instanzprüfung mit 0object durchgeführt wird.

Leistungsoptimierung

Erstellen Sie einen Personenkonstruktor

Im Personenkonstruktor wird für jedes Objekt eine sayName-Methode hinzugefügt.

Derzeit wird unsere Methode innerhalb des Konstruktors erstellt, d erstellt werdenJavaScript-Konstruktor erstellt Objekte (Zusammenfassungsfreigabe)

das heißt, der sayName aller Instanzen ist eindeutig.

Dies wird viel Speicher beanspruchen und für jedes neu erstellte Objekt wird eine neue Methode erstellt.

Lösung: Extrahieren Sie die Methode des neu erstellten Objekts separat wie folgt

nbsp;html>
    <meta>
    <meta>
    <meta>
    <title>Document</title>
    <script>
		//将新创建对象的方法单独提取出来
        function sayName(){
            console.log(this.name)
        }

        //构造一个创建人的类
        function Person(name , age , gender){
            console.log(&#39;指向:&#39;,this);
            this.name = name;
            this.age = age ;
            this.gender = gender;
            this.sayName = sayName;
        }
        var per = new Person(&#39;苏凉&#39;,21,&#39;男&#39;);
        var per1 = new Person(&#39;小红&#39;,18,&#39;女&#39;);
        console.log(per);
        per.sayName();
        per1.sayName();
        console.log(per.sayName == per1.sayName); //true
    </script>
    
对象 instanceof 构造函数

Es ist ersichtlich, dass die sayName-Methode von per und die sayName-Methode von per1 identisch sind. Dies löst das Problem der Neuerstellung einer neuen sayName-Methode beim Erstellen verschiedener Instanzen, was die Speichernutzung erheblich reduziert.

Wissenserweiterung

(1.) Warum brauchen wir einen Konstruktor:

Weil die ersten beiden Möglichkeiten zum Erstellen von Objekten jeweils nur ein Objekt erstellen können.

(2.) Was ist ein Konstruktor:

JavaScript-Konstruktor erstellt Objekte (Zusammenfassungsfreigabe)

Konstruktor: Er abstrahiert einige der gleichen Eigenschaften und Methoden in unseren Objekten und kapselt sie in Funktionen

(3.)利用构造函数创建对象及使用方法

构造函数的函数名从第一个单词开始,每个单词的首写字母都要大写。

JavaScript-Konstruktor erstellt Objekte (Zusammenfassungsfreigabe)

/ /4.在构造函数里面我们的属性和方法前面都必须加this关键字

//声明构造函数语法格式:
function 构造函数名() {
this.属性 = 值;
this.方法 = function() {}
}
//调用构造函数语法格式:
new 构造函数名();

以下是构造函数语法格式的案例:

JavaScript-Konstruktor erstellt Objekte (Zusammenfassungsfreigabe)

【相关推荐:javascript视频教程web前端

Das obige ist der detaillierte Inhalt vonJavaScript-Konstruktor erstellt Objekte (Zusammenfassungsfreigabe). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:csdn.net. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen