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. SSHリモート管理SSH の定義SSH (Secure Shell) は、主にキャラクタ イン...
私は、WinForm と HTML5 を組み合わせた小さなものを作りたいだけなのですが、突然、そこに...
目次背景問題の説明原因分析シミュレーションする総括する背景日常の使用において、MySQL で個別また...
問題を見つける最近、仕事中に問題が見つかりました。問題は、MySQL ディスクがいっぱいだったことで...
1. アイデアMySQL に 1,000,000 件のレコードを挿入するのにたった 6 秒しかかかり...
これは、データベース サーバーが、接続が多すぎるのを避けるために、一定時間非アクティブな状態が続くと...
概要Nginx ロード バランシングは、アップストリーム サーバー (実際のビジネス ロジックによっ...
全文インデックスには特別なクエリ構文が必要です。全文検索はインデックスの有無にかかわらず実行できます...
[mysqlカーソルの使い方と機能]例:現在、テーブル A、B、C の 3 つのテーブルがあります。...
この記事の例では、ミニプログラムのカスタムタブバーコンポーネントをカプセル化するための具体的なコード...
背景数日前、MySql でページングを行っていたときに、ページングに制限 0,10 を使用するとデー...
この記事では、WeChatアプレットで星評価を実装するための具体的なコードを参考までに紹介します。具...
MySQL 5.7.9 のインストールチュートリアルを録画してみんなと共有しましょう環境の紹介:オペ...
1 MySQL5.6 1.1 関連パラメータMySQL 5.6 では、innodb_undo_dir...
CSS には、一般的には使用されない 2 つの疑似クラス、before と :after があります...