1. 範囲簡単に言えば、スコープとは、変数が定義されているプログラム内の領域を指し、現在実行されているコードの変数へのアクセス権を決定します。 ES5 では、一般的にスコープ タイプは次の 2 つだけです。
概念について説明した後、次のコードを見てみましょう。 変数a = 100 関数テスト(){ var b = a * 2 変数a = 200 変数 c = a/2 コンソールログ(b) コンソール.log(c) } test() // ここで何が印刷されるでしょうか? 分析:
つまりNaN、100が出力される。 ES6では、新しいブロックスコープが追加されました 簡単に言えば、中括弧 // ES5 真の場合{ var name = '南九' } console.log(name) // ナンジュウ // ES6 真の場合{ 年齢を18とする } console.log(age) // エラーが報告されます 2. スコープチェーン実行可能コード内の変数にアクセスする場合、まずその変数が現在のスコープ内に存在するかどうかを確認します。存在する場合は、すぐに戻ります。存在しない場合は、親スコープ内を検索し、グローバル スコープが見つかるまで検索を続けます。このスコープ ネスト メカニズムを 3. 語彙の範囲
いわゆるレキシカルスコープは、コードを書くときに変数とスコープをどこに記述するかによって決まります。つまり、レキシカルスコープは静的スコープであり、コードを書くときに決定されます。関数のスコープは、実際に呼び出される場所ではなく、宣言される場所によって決まります。 MDN ではクロージャを次のように定義しています。 関数は、その周囲 (語彙環境) への参照とバンドルされます (または、関数は参照に囲まれています)。このような組み合わせは、 つまり、クロージャを使用すると、内部関数内から外部関数のスコープにアクセスできるようになります。 次のように結論付けることができます。
まずはコードを見てみましょう: var name = 'フロントエンドNanjiu' 関数 say() { console.log(名前) } 言う() 分析: 「Javascript Definitive Guide」という本に次のような一文があります。厳密に言えば、すべての しかし、これは単なる理論的な閉鎖であり、私たちが通常使用するものとは異なります。上記の例は単なる単純なクロージャです。 ECMAScript ではクロージャを次のように定義します。
JavaScript Definitive Guide の別のコードを見てみましょう。 スコープを「グローバルスコープ」にする 関数チェックスコープ(){ スコープを 'ローカルスコープ' にします 関数f(){ 戻りスコープ } 戻り値 f } s = checkscope() とします。 s() // これは何を返しますか? 多くの学生はそれが
スコープの基本ルール: 5. 閉鎖の適用
6. クロージャの欠陥
7. 閉会面接でよくある質問var arr = [] (var i=0;i<3;i++){ arr[i] = 関数(){ コンソールログ(i) } } arr[0]() // 3 arr[1]() // 3 arr[2]() // 3 // ここで、実行中に i は 3 になりました // クロージャを使用して解決する var arr = [] (var i=0;i<3;i++){ arr[i] = (関数(i){ 関数()を返す{ コンソールログ(i) } })(私) } arr[0]() // 0 arr[1]() // 1 arr[2]() // 2 Javascript のスコープとクロージャの詳細に関するこの記事はこれで終わりです。Javascript のスコープとクロージャの詳細については、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
>>: Docker stopはすべてのコンテナを停止/削除します
この記事では、MySQL の左結合における on 条件と where 条件の使用法の違いを例を使って...
序文scp は secure copy の略です。scp は、Linux システムの ssh ログイ...
序文Linux では、スワップ パーティションとスワップ ファイルの 2 種類のスワップ領域を作成で...
必要な項目をループして検証するために、クエリ フォームのいくつかのプロパティを実装したいと考えていま...
多くの場合、ストアド プロシージャを作成するときに配列がよく使用されますが、MySQL ではストアド...
検索テキストボックスにテキストを設定すると、フォーカスを外すと位置がジャンプしますコードをコピーコー...
目次レイアウト部分: <div id="アプリ"> <p>...
降順インデックスとは何ですか?インデックスについてはよくご存知かもしれませんが、降順インデックスにつ...
<br />Web テーブルの分割線を削除する方法。実際、上記の 3 つの表はいずれも ...
以下に示すように、あなたならどのようにそれを達成しますか: 通常、フォントアイコンを使用して中央にプ...
1. スクロールスナップはフロントエンド開発者にとって必須のスキルですCSS スクロール スナップは...
1. MySQLデータベースnacos_configを作成する2. データベース nacos_con...
1. 概要mysql-monitor MYSQL 監視ツール、最適化ツール、1 つの Java Sp...
目次1. JSの特徴1.1 マルチパラダイム1.2 説明1.3 シングルスレッド1.4 ノンブロッキ...
0x0 はじめにまず、ハッシュアルゴリズムとは何でしょうか?メッセージやセッション項目など、一部のデ...