Heim  >  Artikel  >  Web-Frontend  >  Ausführliche Erklärung des strikten Modus „use strict“ in JavaScript

Ausführliche Erklärung des strikten Modus „use strict“ in JavaScript

小云云
小云云Original
2018-03-14 18:06:071384Durchsuche


Zusätzlich zum normalen Laufmodus fügt ECMAscript 5 einen zweiten Laufmodus hinzu: „Strict Mode“. Wie der Name schon sagt, führt dieser Modus dazu, dass Javascript unter strengeren Bedingungen ausgeführt wird.

Warum den strikten Modus verwenden?

  • Beseitigen Sie einige unangemessene und ungenaue Aspekte der Javascript-Syntax und reduzieren Sie einige seltsame Verhaltensweisen.

  • Beseitigen einige unsichere Aspekte der Codeausführung und Gewährleistung der Sicherheit der Codeausführung; neue Versionen von Javascript in der Zukunft.

  • Der „strenge Modus“ spiegelt die vernünftigere, sicherere und strengere Entwicklungsrichtung von Javascript wider, einschließlich IE 10, und viele große Projekte haben bereits damit begonnen, ihn zu übernehmen voll.

  • Andererseits kann derselbe Code im „strikten Modus“ zu unterschiedlichen Ausführungsergebnissen führen. Einige Anweisungen, die im „normalen Modus“ ausgeführt werden können, können im „strikten Modus“ nicht ausgeführt werden. Wenn Sie diese Inhalte beherrschen, können Sie Javascript besser verstehen und ein besserer Programmierer werden.
  • Flag eingeben

So rufen Sie

für ein einzelnes Skript auf

für eine einzelne Funktion

"use strict";

Syntax- und Verhaltensänderungen

Der strikte Modus hat einige Änderungen an der Syntax und dem Verhalten von Javascript vorgenommen.

 <script>    &quot;use strict&quot;;
    console.log("这是严格模式。");
  </script>
Explizite Deklaration globaler Variablen

Wenn einer Variablen im Normalmodus ein Wert zugewiesen wird, ohne deklariert zu werden, wird sie standardmäßig auf eine globale Variable gesetzt. Der strikte Modus verbietet diese Verwendung und globale Variablen müssen explizit deklariert werden.
function strict(){    "use strict";
    return "这是严格模式。";
  }
  function notStrict() {    return "这是正常模式。";
  }

Daher müssen Variablen im strikten Modus vor der Verwendung mit dem Befehl var deklariert werden.

Dem Schlüsselwort this ist es untersagt, auf das globale Objekt zu verweisen.

Wenn Sie daher bei Verwendung des Konstruktors vergessen, new hinzuzufügen, zeigt dies nicht mehr auf das globale Objekt. aber es wird ein Fehler gemeldet.

"use strict";
  v = 1; // 报错,v未声明  for(i = 0; i < 2; i++) { // 报错,i未声明  }

Das Löschen von Variablen ist verboten

Variablen können im strikten Modus nicht gelöscht werden. Es können nur Objektattribute gelöscht werden, deren konfigurierbare Eigenschaft auf „true“ gesetzt ist.

function f(){    return !this;
  } 
  // 返回false,因为"this"指向全局对象,"!this"就是false  function f(){     "use strict";
    return !this;
  } 
  // 返回true,因为严格模式下,this的值为undefined,所以"!this"为true。

Objekte können keine Attribute mit doppelten Namen haben

function f(){    "use strict";
    this.a = 1;
  };
  f();// 报错,this未定义
Wenn ein Objekt im normalen Modus mehrere Attribute mit doppelten Namen hat, überschreibt das zuletzt zugewiesene Attribut den vorherigen Wert. Im strikten Modus handelt es sich um einen Syntaxfehler.

Eine Funktion kann keine Parameter mit demselben Namen haben

"use strict";
  var x;
  delete x; // 语法错误  var o = Object.create(null, {'x': {
      value: 1,
      configurable: true  }});
  delete o.x; // 删除成功
Wenn eine Funktion im normalen Modus mehrere Parameter mit demselben Namen hat, können Sie diese mit arguments[i] lesen. Im strikten Modus handelt es sich um einen Syntaxfehler.

Verwandte Empfehlungen:

"use strict";
  var o = {
    p: 1,
    p: 2  }; // 语法错误

Erklärung von Beispielen für den strikten JS-Modus

 "use strict";
  function f(a, a, b) { // 语法错误    return ;
  }

Detaillierte Einführung in den strikten Modus in JavaScript

Detaillierte Erläuterung der Javascript-Fähigkeiten im strengen JavaScript-Modus

Das obige ist der detaillierte Inhalt vonAusführliche Erklärung des strikten Modus „use strict“ in JavaScript. 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