JavaScript の名前空間: "var FOO = FOO || {}" について
JavaScript では、次のコードがよく見られます。ソース ファイルの先頭:
var FOO = FOO || {};
このコードは条件演算子 (||) を使用しています。空のオブジェクト ({}) を変数 (FOO) に割り当てます (変数 (FOO) がまだ存在しない場合)。この手法は、関数や変数を整理するために使用される名前付きオブジェクトであるネームスペースを作成するためによく使用されます。
条件演算子は次のように機能します。変数 FOO が未定義または null (初期状態) の場合、空のオブジェクトが割り当てられます。ただし、FOO がすでに定義されている場合は、その既存の値が使用されます。
ネームスペースを使用すると、同じネームスペースを共有する複数のファイルで、グローバル オブジェクトを汚すことなく関数や変数を定義できます。たとえば、次の 2 つのファイルについて考えてみましょう:
ファイル 1:
var MY_NAMESPACE = MY_NAMESPACE || {}; MY_NAMESPACE.func1 = { };
ファイル 2:
var MY_NAMESPACE = MY_NAMESPACE || {}; MY_NAMESPACE.func2 = { };
この場合、両方のファイルが MY_NAMESPACE 名前空間を共有します。したがって、ロードされる順序に関係なく、func1 と func2 の両方が MY_NAMESPACE オブジェクト内で定義されます。最初のファイルは初期名前空間を作成し、後続のファイルは既存のオブジェクトを拡張して、ファイル間で一貫したオブジェクト構造を保証します。
この手法は、スクリプトの実行順序が不確実な非同期スクリプトの読み込みに特に役立ちます。名前空間を共有するすべてのスクリプトが同じオブジェクトを使用するようにすることで、ファイルのロード順序は定義されたオブジェクトの整合性に影響しません。
以上が「var FOO = FOO || {};」はどのように行われるのでしょうか? JavaScript で名前空間を作成および管理しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。