Heim > Web-Frontend > js-Tutorial > Hauptteil

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

小云云
Freigeben: 2018-03-14 18:06:07
Original
1390 Leute haben es durchsucht


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";
Nach dem Login kopieren

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>
Nach dem Login kopieren
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 "这是正常模式。";
  }
Nach dem Login kopieren

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未声明  }
Nach dem Login kopieren

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。
Nach dem Login kopieren

Objekte können keine Attribute mit doppelten Namen haben

function f(){    "use strict";
    this.a = 1;
  };
  f();// 报错,this未定义
Nach dem Login kopieren
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; // 删除成功
Nach dem Login kopieren
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  }; // 语法错误
Nach dem Login kopieren

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

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

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!

Verwandte Etiketten:
Quelle:php.cn
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
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!