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はすべてのコンテナを停止/削除します
目次文章1. 機械を準備する2. Dockerをインストールする1. 依存パッケージをインストールす...
mysql-5.7.17 のインストールについては記事の下部で紹介されているので、参考にしてください...
Linux での ssh サービス構成など、ssh サーバー構成に関する記事は多数あります。ここでは...
この記事では、タイピングゲームを実装するためのJavaScriptの具体的なコードを参考までに紹介し...
VMware Workstation 14 ProにCentOS 7.0をインストールする具体的な方...
今日、MySQL の無料インストール版をデプロイしたところ、テーブル 'mysql.plug...
最終的な効果は次のようになります。アニメーションは2つのステップに分かれていますランニング軌道を開発...
Zabbix 管理者ログイン パスワードのリセットに関する問題は次のとおりです。 1. 問題の説明:...
目次1.配列を初期化する2. 配列の合計、最大値、最小値3. エラー値をフィルタリングする4. 論理...
1. MySQLをダウンロードするMySQL 公式 Web サイトにログインし、MSI インストー...
最近、製品部門のユーザーエクスペリエンスチームの学生は、アライアンス環境における広告に関する一連の研...
予防1) 先頭にインタープリターを追加します: #!/bin/bash 2) 構文のインデントに 4...
ステップ 1: yum install httpd -y #httpd サービスをインストールします...
目次序文列挙可能なプロパティ反復可能なオブジェクトforEachメソッドとmapメソッドチェーン呼び...
FlashFXPのダウンロードアドレスは、https://www.jb51.net/softs/95...