Heim  >  Artikel  >  Web-Frontend  >  Fortgeschrittene JS-bezogene Kenntnisse

Fortgeschrittene JS-bezogene Kenntnisse

一个新手
一个新手Original
2017-10-19 09:16:361410Durchsuche

Vererbung: Andere haben Attribute und Methoden, die das aktuelle Objekt nicht hat, und verwenden sie für Ihren eigenen Gebrauch, was Vererbung ist

1 Gemischte Vererbung


var I={ };    
var obj = {
                name: 'jack',
                age:18,
                sayGoodbye : function () {
                                        console.log("goodbye") ;
                }
    }// 混入式继承, a中 将继承obj的所有属性
    for (var k in obj ) {
        a[k] = obj [k] ;
    }

2. Prototypische Vererbung

  1. Mithilfe der Funktion, dass Mitglieder im Prototyp von ihren zugehörigen Objekten gemeinsam genutzt werden können, kann die Vererbung implementiert werden

  2. Implementierungsschritte

  a) Das Hinzufügen neuer Mitglieder zum Prototypobjekt (durch die dynamischen Eigenschaften des Objekts) ist keine Vererbung im engeren Sinne Instanzobjekt erbt den Prototyp

b) Ersetzt das Prototypobjekt direkt


    1. Constructor.prototypr = neues Objekt

    2. Das Instanzobjekt erbt den Prototyp (neues Objekt)

    3. Wenn das Objekt ursprünglich Eigenschaften hat und Methoden: Die Verwendung der Ersetzungsmethode überschreibt die ursprünglichen Eigenschaften und Methoden. Methode

c) Verwenden Sie die Mischmethode, um Mitglieder zum Prototypobjekt hinzuzufügen


    1. Mischen, Durchlaufen der Eigenschaften und Methoden eines Objekts, Zuweisen von Werten zu einem anderen Objekt für. ..in...

3. Klassische Vererbung

js

 var object 1 = Object.creat(object 2);

Zu diesem Zeitpunkt erbt das erstellte Objekt 1 von Objekt 2

Die Methode Object.creat weist Kompatibilitätsprobleme auf

Lösung:   

  1. Überprüfen Sie, ob Wenn nicht, fügen Sie die Methode „create“ direkt zum Objekt hinzu. Passen Sie die Funktion an und bestimmen Sie, ob der Browser die Methode „Object.create“ innerhalb der Funktion unterstützt Objekt und geben Sie es zurück, andernfalls rufen Sie direkt


function creat(obj) {    
    if (object.creat){            
    return Object.creat(obj);
       }else{
            function F(){
                }
            F.prototype = obj;            
            return new F();
            }
    }
So erweitern Sie eingebaute Objekte sicherer auf


function MyArray() {    
this.name = "我是数组"     
}
var arr = new Array();
MyArray.prototype =arr ; // 继承后,我的数组中 就有了原生数组对象的所有属性和方法
var  myArr = new MyArray() ;   // myArr 这个对象就继承自arr
Prototypenkette

Was ist eine Prototypenkette?

Jeder Konstruktor hat Prototypobjekte, und jedes Objekt hat einen Konstruktor. Das Prototypobjekt jedes Konstruktors ist ein Objekt ist ein Konstruktor
und dann wird eine Kettenstruktur gebildet, die wir Prototypenkette nennen

Was ist prototypische Vererbung?

Durch Ändern der Struktur der Prototypkette wird die Vererbung durch prototypische Vererbung erreicht.

Prinzip der Attributsuche

  1. Zuerst beim Zugriff auf ein Mitglied eines Objekts Überprüfen Sie, ob es eines gibt. Verwenden Sie einfach

  2. . Wenn nicht, gehen Sie zum Prototypobjekt des aktuellen Objekts, um es zu finden 🎜>

  3. Wenn es nicht gefunden wird, gehen Sie zum Prototypobjekt, um es zu finden. Wenn es gefunden wird, verwenden Sie direkt
  4. Leiten Sie das Objekt. Wenn es immer noch nicht gefunden wird, geben Sie null zurück
  5. Die Vererbung, die durch Ändern der Vererbungsstruktur der Prototypkette erreicht wird, wird als prototypische Vererbung bezeichnet



Die im p-Objekt enthaltenen Objekte sind: Mitglieder von Person.prototype und Mitglieder, die ihm gehören
function Person() { } ;var p = new Person() ;

Mitglieder von Person.prototype sind: Mitglieder von Object.prototype und Mitglieder von sich selbst

  Object.prototype-Mitglieder:

Konstruktor: Zeigt auf den Konstruktor, der sich auf den Prototyp bezieht

HasOwnProperty-Methode: Bestimmen Sie, ob das Exklusive selbst ist hat ein bestimmtes Attribut

properIsEnumerable-Methode: 1. Bestimmen Sie das Attribut. Ob es zum Objekt selbst gehört, 2. Bestimmen Sie, ob das Attribut durchlaufen werden kann

 toString toLocalString: Konvertieren Sie das Objekt in einen String Der lokale Einstellungsmodus, der angewendet wird, wenn toLocalString in eine Zeichenfolge konvertiert wird

 valueOf-Methode: Wenn das Objekt an der Operation teilnimmt, wird zuerst die valueOf-Methode aufgerufen, um den Wert des Objekts zu erhalten Bei der Operation wird die toString-Methode

aufgerufen. __proto__-Attribut: Zeigt auf das Prototypobjekt des aktuellen Objekts

Funktion

3 Möglichkeiten, eine Funktion zu erstellen:

Direkte Deklaration

Funktionsausdruck

new Function ()

Sie können Function verwenden, um Funktionen zu erstellen:

Syntax:


 函数名 =  Function ( ) ;  函数名 =  Function();  函数名 =  Function(,,,...
var distinct = new Function(`
              var arr = [];
              for (var i = 0; i < arguments.length; i++) {
                    if(arr.indexOf(arguments[i])==-1){
                        arr.push(arguments[i]);
                    }
              }
              return arr;
        `);
//可以使用Ese下边的符号 来连接字符串进行换行操作 但是存在兼容性问题
eval
console.log(distinct(1, 2, 34, 34, 5, 5));

kann die Zeichenfolge in JS-Code konvertieren und ausführen Hinweis: Wenn Sie eval zum Parsen der JSON-Formatzeichenfolge verwenden, beachten Sie bitte, dass {} in ein Codesegment analysiert wird

1 Sie können „var variable name="

eval( "var variable name=" + string in JSON format);

2. Sie können ()
eval("("+JSON format string+")")

statische Mitglieder und Instanzmitglieder
Statische Mitglieder Die Eigenschaften und Methoden, auf die über den Konstruktor zugegriffen wird, sind statische Mitglieder

Instanzmitglieder

Die Eigenschaften und Methoden, auf die über das Objekt zugegriffen wird (Instanz) sind Instanzmitglieder

Das obige ist der detaillierte Inhalt vonFortgeschrittene JS-bezogene Kenntnisse. 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