Heim >Web-Frontend >js-Tutorial >Beispielerklärung für den strikten JS-Modus
Dieser Artikel organisiert hauptsächlich relevante Wissenspunkte und Codebeispiele im JS-strict-Modus. Wenn Sie interessiert sind, folgen Sie dem Editor, um gemeinsam zu lernen.
Der sogenannte Strict-Modus ist eigentlich eine Zeichenfolge „use strict“, die keiner Variablen zugewiesen wird
Wenn diese Eingabeaufforderung im globalen Bereich angegeben wird , dann befindet sich das gesamte Skript im strikten Modus. Sie können den strikten Modus auch nur in der Funktion
1 aktivieren. Im strikten Modus gibt es keine globalen Variablen
a="test"
Strikt Im Modus wird ein Fehler gemeldet, im nicht-strikten Modus jedoch normal
2. Variablen löschen
Var hat drei Deklarationssituationen
var Globale Variablen, deklariert in
var Lokale Variablen, deklariert in
Globale Variablen, deklariert in eval ()
Der erste und der zweite Fall können nicht mit Löschen gelöscht werden.
Erstens: Obwohl das im ersten Fall deklarierte globale Objekt ein Attribut von Windows ist, hat dieses Attribut configurable=false und kann daher nicht gelöscht werden
Der zweite Wenn es sich um lokale Variablen handelt, wissen Sie nicht einmal, wer das angehängte Objekt ist.
Der dritte Fall von eval() wird später besprochen.
Zurück zum Thema. Das heißt, im nicht strikten Modus können Sie Variablen löschen, dies schlägt jedoch fehl und gibt „false“ zurück.
Beim Löschen von Variablen im strikten Modus wird ein Fehler gemeldet.
3. Objekt
In den folgenden Situationen wird beim Bedienen des Objekts ein Fehler gemeldet
Das Zuweisen eines Werts zu einem schreibgeschützten Attribut führt zu einem Fehler
Die Verwendung von delete für nicht konfigurierbare Eigenschaften führt zu einem Fehler
Das Hinzufügen von Eigenschaften zu nicht -Erweiterbare Objekte melden einen Fehler
Bei der Verwendung von Objektliteralen müssen Eigenschaftsnamen eindeutig sein. Beispielsweise wird
var person={ name:"1", name:"2" }
im nicht-strikten Modus standardmäßig auf den zweiten Wert gesetzt, und im strikten Modus wird ein Fehler gemeldet.
4. Funktion
Der strenge Modus erfordert, dass Funktionsparameternamen eindeutig sein müssen
function(n,n){ // todo }
Im nicht strikten Modus meldet diese Funktionsdeklaration keinen Fehler. Nur auf den zweiten Parameter kann über den Parameternamen zugegriffen werden, und auf den ersten Parameter muss über Argumente zugegriffen werden.
Argumente unterscheiden sich auch in den beiden Modi
Im nicht-strikten Modus wird die Änderung des Werts des benannten Parameters im Argumentobjekt widergespiegelt , beide Die Werte sind unabhängig.
Argumente.callee (referenziert die Funktion selbst) und arguments.caller (referenziert die aufrufende Funktion) wurden entfernt.
Im strikten Modus können Funktionsnamen keine js-reservierten Wörter verwenden
** Im strikten Modus können Funktionen nur auf der obersten Ebene des Skripts und innerhalb des deklariert werden Funktion in der if-Anweisung. Die Deklaration einer Funktion führt zu einem Syntaxfehler. **
if(true){ function(){ // 严格模式下报错 } }
5.this
Verwenden Sie apply() der Funktion im nicht-strikten Modus, rufen Sie auf () wird der übergebene Null- oder undefinierte Wert in ein globales Objekt konvertiert. Im strikten Modus ist das This einer Funktion immer der angegebene Wert, unabhängig davon, welcher Wert angegeben wird.
var a="1"; function test(){ console.log(this.a) } test.call(null) 在非严格模式下会输出1,严格模式下this就指代的就是null,null没有a属性,就会报错。
Verwandte Empfehlungen:
Eine kurze Einführung in die Analysereihenfolge und den Umfang von JS und dem strengen Modus
Analyse des JS-Parsing-Reihenfolgebereichs im strengen Modus
Detaillierte Erläuterung dieses Zeigeproblems im strengen JavaScript-Modus
Das obige ist der detaillierte Inhalt vonBeispielerklärung für den strikten JS-Modus. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!