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はすべてのコンテナを停止/削除します
ここでは、CSS テクニックを巧みに使用することで、HTML を変更せずにブログやテンプレートの外観...
この記事の例では、商品詳細ページ機能を実現するためのVueの商品タブの具体的なコードを参考までに共有...
1. テキストの書式設定: この例では、HTML ファイル内のテキストを書式設定する方法を示します...
多くのウェブサイトを閲覧すると、ブラウザのアドレスバーの前に小さなアイコンがあり、ブラウザのタブの位...
CSS で要素の水平方向と垂直方向の中心を設定することは、非常に一般的な要件です。しかし、理論的には...
目次自動インクリメント ID を更新する理由は何ですか?質問解決方法これは私が知っている問題ですが、...
目次1. 背景2. ローカルカスタム指示3. グローバルカスタム指示4.1 カスタムコマンドフック関...
背景: 1. データベースに通知テーブルがある あなたは見ることができますgmt_create、通知...
この記事では、CentOS 7 環境で MySQL 5.6 の複数のインスタンスを作成する方法につい...
この記事では、ネイティブ JS を使用して実装された実用的な Web ナビゲーション バー効果を紹介...
1. 重複行を見つける blog_user_relation a から * を選択 WHERE (...
目次1. レシピ集1.1 プロジェクトの背景1.2 テクノロジースタック1.3 開発環境1.4. プ...
今日は、ネイティブ JS で実装された見栄えの良いカウンターを紹介します。効果は次のとおりです。 以...
目次01-イベントバブリング1.1- イベントバブリングの概要1.2-イベントバブリングの利用(イベ...
1. イメージをプルするまず、次のコマンドを実行して、イメージをローカル コンピューターにダウンロー...