1. 概要1.1 厳密モードとは何ですか?厳密モードは、 現在、ほとんどのブラウザは厳格モードをサポートしていますが、一部の古いバージョンのブラウザはまだ厳格モードをサポートしていないため、厳格モードの機能をテストせずに厳格モードを使用しないでください。 1.2 厳密モードの目的厳密モードを使用する目的は次のとおりです。 まず、厳密モードでは、 2. 厳密モードを有効にする
2.1 厳格モードをグローバルに有効にするグローバル厳格モードを有効にするには、すべてのコードの前に文字列を入力するだけです。文字列は次のとおりです。 "use strict"; // または 'use strict'; 前の 2.2 ローカルで厳密モードを有効にするローカルで厳密モードを有効にするには、指定した関数の最初の行に文字列「 厳密モードを有効にするサンプルコードは次のとおりです。 //厳密モードをグローバルに有効にする //"use strict" 100 です コンソールログ(v) 関数fun() { // ローカルで厳密モードを有効にする 'use strict' 200 です コンソールログ(vv) } // fun() は例外をスローします vv は定義されていません 3. 厳密モードの変数3.1 変数の偶発的な作成を防ぐいわゆる誤って作成された変数は、var キーワードを使用せずに宣言された変数です。厳密モードでは、グローバル変数が誤って作成されると例外がスローされます。 サンプルコードは次のとおりです。 「厳密な使用」 // 非厳密モードでは、このような変数を作成してもエラーは報告されませんが、厳密モードでは、このような変数を作成すると例外がスローされます v = 100 コンソールログ(v) 3.2 サイレント失敗が例外に変わるサイレント失敗はエラーも影響もないことを意味します。厳密モードでは例外に変換されます。 3.3 削除キーワードを無効にする非厳密モードでは、グローバル変数でdeleteキーワードを使用すると何も表示されずに失敗しますが、厳密モードでは例外がスローされます。サンプルコードは次のとおりです。 「厳密な使用」 変数v = 100 delete v // SyntaxError: Deleteofanunqualifiedidentifierinstrictmode. コンソールログ(v) 3.4 変数名の制限厳密モードでは、 4. 厳密モードのオブジェクト4.1 削除できない属性非厳密モードでは、削除できないプロパティで サンプルコードは次のとおりです。 「厳密な使用」 delete Object.prototype; //例外をスローする 4.2 読み取り専用プロパティの割り当て非厳密モードでは、読み取り専用プロパティに値を割り当てると何も表示されずに失敗しますが、厳密モードでは例外がスローされます。サンプル コードは次のとおりです。 「厳密な使用」 var obj = {} オブジェクト.defineProperty(obj, 'name', { 価値: 「お粥一杯」 }) obj.name = 'Yiwan Zhou' //例外をスローします 4.3 拡張不可能なオブジェクト拡張不可能なオブジェクトに新しいプロパティを追加すると、非厳密モードでは何も表示されずに失敗しますが、厳密モードでは例外がスローされます。 サンプルコードは次のとおりです。 // グローバル厳格モードを有効にする 'use strict' var obj = {} //拡張不可にする Object.preventExtensions(obj) //オブジェクト属性を拡張します。obj.name = 'Yiwan Zhou' //例外をスローします 5. 厳密モードでの機能5.1 パラメータ名は一意でなければならない非厳密モードでは関数パラメータを繰り返すことができますが、厳密モードでは関数パラメータが繰り返されると例外がスローされます。サンプルコードは次のとおりです。 「厳密な使用」 関数fun(a, a, b) { コンソールログ(a + a + b) } /* *非厳密モードでの結果は7=2+2+3です *厳密モードでは例外がスローされます*/ 楽しい(1, 2, 3) 5.2 議論の相違
違いは次のとおりです。
サンプルコードは次のとおりです。 「厳密な使用」 関数fun(v) { '100' の場合 コンソールログ(v) コンソール.log(引数[0]) } /* * 非厳密モードで印刷された結果は100、100 *厳密モードで印刷された結果は100、200です */ 楽しい(200) 5.3 arguments.callee プロパティ非厳密モードでは、現在の関数名を返す サンプルコードは次のとおりです。 「厳密な使用」 関数fun(){ console.log(引数.呼び出し先); } fun()//例外をスローする 5.4 関数宣言の制限厳密モードでは、関数はグローバル スコープとローカル スコープでのみ宣言できます。これらの 2 つのスコープの外部 (if ステートメント ブロックなど) で関数構文を宣言するとエラーになります。 サンプルコードは次のとおりです。 「厳密な使用」 関数fun() { console.log(引数.呼び出し先) } fun() //例外をスローする 6. eval() のスコープを拡大する厳密モードでは、 外部で使用すると例外がスローされます。サンプルコードは次のとおりです。 「厳密な使用」 評価('var v=100') console.log(v) //例外をスローする 7. これを抑制する
サンプルコードは次のとおりです。 // 厳密モードを有効にする 'use strict' 変数v = 100 関数fn() { コンソールログ(this.v) } var obj = { v: 200, } fn.call(obj) //これはグローバルオブジェクトを指します 結論: この記事では基本的に、厳格モードのすべての状況を紹介しており、日常の開発における厳格モードに関連する問題を解決するのに十分です。 これで、 以下もご興味があるかもしれません:
|
<<: dockerfile-maven-plugin 使用ガイドの概要
>>: 適応幅(パーセンテージ)に応じて Div の高さを調整する純粋な CSS
この記事では、テーブルのページング効果を実現するためのjQueryの具体的なコードを参考までに紹介し...
コアはmysqldumpとランタイムです操作は実際にはそれほど難しくありません。バックアップ操作を実...
目次1. Ant Design Vueを統合する2. コンポーネントの使用1. 完全な引用2. コン...
フロントエンドエンジニアとして、IE は私たちにとって馴染み深いものであるはずです。設計案を実装する...
目次一方向データフローの説明Vue2.x の使用法親コンポーネントに変更を通知するイベントのフォーム...
導入クロージャは JavaScript の非常に強力な機能です。いわゆるクロージャは関数内の関数です...
半夜かけてようやくブログのスタイルを大体完成させることができました。ブログ全体が青を基調としていて、...
フィルターとバックドロップフィルターにはいくつかの違いがあります。フィルターは現在の要素だけでなく、...
目次マクスウェルについてMaxwellの設定と使用1. Maxwellインストールパッケージをダウン...
1. はじめに周知のように、データベース ミドルウェアの読み取り/書き込み分離のアプリケーション シ...
目次1. サーバー2. クライアント3. テストサービス1. サーバー1. YUMソースを使用してN...
ブラウザでのページのレンダリング時間をできるだけ短縮するにはどうすればよいでしょうか? この記事は、...
MySQLは重複データを処理します一部の MySQL テーブルには重複レコードが含まれている場合があ...
序文MySQL データのインポートとエクスポートは mysqldump コマンドで解決できることは誰...
フロントエンド開発者としては、IEの落とし穴は避けて通れません。他のブラウザはいいのにIEは壊れてい...