目次
1. 実行環境の例の説明
2. 実行環境はどのように機能しますか?

JS実行環境例の紹介

Mar 07, 2018 am 10:37 AM
javascript 導入

「実行環境」、この言葉を聞くと混乱するかもしれません。多くの文献では「実行コンテキスト」とも呼ばれていますが、実際には同じものです。書籍や資料では非常に複雑に説明されていることがよくありますが、この部分は JS で理解するのが難しいため、この記事ではこの概念を簡単に説明します。

1. 実行環境の例の説明

まず例を見てみましょう:
ブラウザコンソールに次のように入力します:

var a=1;console.log(window.a);console.log(a);
ログイン後にコピー

結果は出力1です。明らかに、変数はウィンドウオブジェクトの属性です。
それでは、変数 a の実行環境は何ですか?
答えるのは難しくないと思います。それはウィンドウ オブジェクトです。確かに、ウィンドウ オブジェクトは変数 a の実行環境であり、最も周辺的な実行環境であるため、グローバル実行環境と呼ばれます。ここで、a はデフォルトでグローバル実行環境に定義されているため、a と window.a は同じです。
次の例を見てみましょう:

function output(){
    var a=1;
    console.log(a);
}
ログイン後にコピー

この例では、a が関数内で定義されており、a の実行環境が関数の実行環境 (出力) になります。
ウィンドウに

console.log(a);
ログイン後にコピー

と入力すると、 a は関数の出力でのみ表示されるため、エラーが報告されます。
しかし、

console.log(output);
ログイン後にコピー

と入力すると、関数は正常に表示されます。関数出力の実行環境はウィンドウなので、もちろんウィンドウに表示することもできます。

2. 実行環境はどのように機能しますか?

出力関数がウィンドウ環境にあることがわかりました。プログラムが出力関数を実行すると、次のように推測できるはずです。
ウィンドウ環境が出力関数環境に制御を渡し、出力環境がホーム フィールドになります。
それでは、舞台裏で実際に何が起こっているのでしょうか?
JS には実行環境スタックまたは実行コンテキスト スタックと呼ばれるものがあります。スタックが何であるかわからない場合は、データ構造を記入する必要があります。
箱を積み上げたように、グローバル実行環境は実行環境スタックの一番下に配置されます。出力関数を実行する場合、この関数の実行環境もボックスにパッケージ化され、グローバル実行環境の上に「スタック」されます。グローバル環境で他の関数を実行し続けたい場合は、下のボックスから何かを取得するのと同じように、最初に出力関数を実行する必要があります。比喩的に言えば、下のボックスを移動する前に上のボックスを取り除くようなものです。

関連する推奨事項:

JavaScriptの型、パラメータ、実行環境を理解する方法

実行環境とスコープインスタンスの詳細な説明

JavaScriptのスコープチェーンと実行環境

以上がJS実行環境例の紹介の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Python ORM パフォーマンス ベンチマーク: さまざまな ORM フレームワークの比較 Python ORM パフォーマンス ベンチマーク: さまざまな ORM フレームワークの比較 Mar 18, 2024 am 09:10 AM

オブジェクト リレーショナル マッピング (ORM) フレームワークは、Python 開発において重要な役割を果たします。オブジェクト データベースとリレーショナル データベースの間にブリッジを構築することで、データ アクセスと管理を簡素化します。さまざまな ORM フレームワークのパフォーマンスを評価するために、この記事では次の一般的なフレームワークに対してベンチマークを実行します。 sqlAlchemyPeeweeDjangoORMPonyORMTortoiseORM テスト方法 ベンチマークでは、100 万レコードを含む SQLite データベースを使用します。テストでは、データベースに対して次の操作を実行しました。 挿入: テーブルに 10,000 件の新しいレコードを挿入します。 読み取り: テーブル内のすべてのレコードを読み取ります。 更新: テーブル内のすべてのレコードの 1 つのフィールドを更新します。 削除: テーブル内のすべてのレコードを削除します。 各操作

簡単な JavaScript チュートリアル: HTTP ステータス コードを取得する方法 簡単な JavaScript チュートリアル: HTTP ステータス コードを取得する方法 Jan 05, 2024 pm 06:08 PM

JavaScript チュートリアル: HTTP ステータス コードを取得する方法、特定のコード例が必要です 序文: Web 開発では、サーバーとのデータ対話が頻繁に発生します。サーバーと通信するとき、多くの場合、返された HTTP ステータス コードを取得して操作が成功したかどうかを判断し、さまざまなステータス コードに基づいて対応する処理を実行する必要があります。この記事では、JavaScript を使用して HTTP ステータス コードを取得する方法を説明し、いくつかの実用的なコード例を示します。 XMLHttpRequestの使用

ビッグデータ プロジェクトにおける Python ORM の適用 ビッグデータ プロジェクトにおける Python ORM の適用 Mar 18, 2024 am 09:19 AM

オブジェクト リレーショナル マッピング (ORM) は、開発者が SQL クエリを直接記述せずにオブジェクト プログラミング言語を使用してデータベースを操作できるようにするプログラミング テクノロジです。 Python の ORM ツール (SQLAlchemy、Peeweee、DjangoORM など) は、ビッグ データ プロジェクトのデータベース操作を簡素化します。利点 コードの単純さ: ORM により、長い SQL クエリを作成する必要がなくなり、コードの単純さと読みやすさが向上します。データの抽象化: ORM は、アプリケーション コードをデータベース実装の詳細から分離する抽象化レイヤーを提供し、柔軟性を向上させます。パフォーマンスの最適化: ORM は多くの場合、キャッシュとバッチ操作を使用してデータベース クエリを最適化し、それによってパフォーマンスを向上させます。移植性: ORM により、開発者は次のことが可能になります。

Golang でのポインター変換のベスト プラクティスの例を学ぶ Golang でのポインター変換のベスト プラクティスの例を学ぶ Feb 24, 2024 pm 03:51 PM

Golang は、さまざまなアプリケーションやサービスの開発に使用できる強力で効率的なプログラミング言語です。 Golang では、ポインタは非常に重要な概念であり、データをより柔軟かつ効率的に操作するのに役立ちます。ポインタ変換とは、異なる型間のポインタ操作のプロセスを指します。この記事では、具体的な例を使用して、Golang におけるポインタ変換のベスト プラクティスを学びます。 1. 基本概念 Golang では、各変数にはアドレスがあり、アドレスはメモリ内の変数の位置です。

Oracle インスタンスの数とデータベースのパフォーマンスの関係 Oracle インスタンスの数とデータベースのパフォーマンスの関係 Mar 08, 2024 am 09:27 AM

Oracle インスタンスの数とデータベースのパフォーマンスの関係 Oracle データベースは、業界でよく知られたリレーショナル データベース管理システムの 1 つであり、エンタープライズ レベルのデータ ストレージと管理で広く使用されています。 Oracle データベースでは、インスタンスは非常に重要な概念です。インスタンスとは、メモリー内のOracleデータベースの実行環境を指します。各インスタンスには独立したメモリー構造とバックグラウンド・プロセスがあり、ユーザー・リクエストの処理とデータベース操作の管理に使用されます。インスタンスの数は、Oracle データベースのパフォーマンスと安定性に重要な影響を与えます。

Python ORM を使用して効率的なデータ永続性を実装する Python ORM を使用して効率的なデータ永続性を実装する Mar 18, 2024 am 09:25 AM

オブジェクト リレーショナル マッピング (ORM) は、オブジェクト指向プログラミング言語とリレーショナル データベース間の橋渡しを可能にするテクノロジーです。 pythonORM を使用すると、データの永続化操作が大幅に簡素化され、アプリケーションの開発効率と保守性が向上します。利点 PythonORM を使用すると、次のような利点があります。 定型コードの削減: ORM は SQL クエリを自動的に生成するため、大量の定型コードを記述する必要がなくなります。データベース対話の簡素化: ORM は、データベースと対話するための統合インターフェースを提供し、データ操作を簡素化します。セキュリティの向上: ORM はパラメータ化されたクエリを使用するため、SQL インジェクションなどのセキュリティの脆弱性を防ぐことができます。データの一貫性の促進: ORM はオブジェクトとデータベース間の同期を保証し、データの一貫性を維持します。持つORMを選択してください

Python Tkinter を使用してプロジェクトに GUI チャームを追加する Python Tkinter を使用してプロジェクトに GUI チャームを追加する Mar 24, 2024 am 09:46 AM

Tkinter は、Python でグラフィカル ユーザー インターフェイス (GUI) を作成するための強力なライブラリです。シンプルさ、クロスプラットフォーム互換性、Python エコシステムとのシームレスな統合で知られています。 Tkinter を使用すると、ユーザー フレンドリーなインターフェイスをプロジェクトに追加でき、ユーザー エクスペリエンスが向上し、アプリケーションとの対話が簡素化されます。 Tkinter GUI アプリケーションの作成 Tkinter を使用して GUI アプリケーションを作成するには、次の手順を実行します: Tkinter ライブラリをインポートします: importtkinterastk Tkinter メイン ウィンドウを作成します: root=tk.Tk() メイン ウィンドウを構成します: ウィンドウのタイトル、サイズ、位置を設定しますなど。GUI 要素の追加: Tki の使用

初心者からマスターまで: Java Git の短期集中コース 初心者からマスターまで: Java Git の短期集中コース Mar 27, 2024 pm 10:41 PM

Git は、チームがソフトウェア開発で共同作業するのに役立つ分散バージョン管理システムです。 Java 開発者にとって、Git はコード変更の管理、コード履歴の追跡、他のユーザーとのコラボレーションのためのプラットフォームを提供するため、Git を理解することが非常に重要です。初心者向けの Git のインストール (基本を理解する): Git ソフトウェアをインストールし、環境変数を設定します。リポジトリの作成: gitinit を使用してローカル リポジトリを作成します。ファイルの追加: gitadd を使用してファイルをステージング領域に追加します。変更をコミットする: gitcommit を使用して、ステージング領域の変更をローカル リポジトリにコミットします。リポジトリの中間 (コラボレーションおよびバージョン管理) クローン作成: gitclone を使用して、リモート リポジトリからローカル コピーのクローンを作成します。分岐とマージ: ブランチを使用して、コードの分離されたコピーを作成します。

See all articles