ホームページ >ウェブフロントエンド >jsチュートリアル >js(名前空間)のモジュール解析

js(名前空間)のモジュール解析

不言
不言オリジナル
2018-07-23 11:23:361809ブラウズ

この記事は、js のモジュラー解析 (名前空間) を共有します。必要な友人はそれを参照できます。

コードをモジュール化できるように、つまりさまざまなシナリオでモジュールを再利用できるように、コードはモジュールに編成されています。
モジュールは独立した js ファイルです。モジュール ファイルには、クラス定義、関連クラスのセット、ユーティリティ関数ライブラリ、または実行されるコードを含めることができます。コードはモジュールの形式で記述し、js コード部分をモジュールとみなすことができます。
モジュールの目的は、プログラム開発をサポートし、分散ソースからのコードアセンブリを処理し、コードが正しく実行できるようにすることです

名前空間内のオブジェクトとして使用します

グローバル変数の汚染を回避し、オブジェクトを名前空間として使用し、関数の値を結合します。 名前空間オブジェクトの属性が保存されます (つまり、グローバル変数を通じて参照されます)

var collections;  // 先声明一个全局变量
if (!collections) // 如果它原先不存在
  collections = {}; //创建一个新对顶层命名空间,加判断是因为防止出现覆盖
collections.sets = {};  // 将sets命名空间创建在其内部

// 下面开始定义相关的类
collections.sets.AbstractSet = function(){};

set 名前空間で set クラスを頻繁に使用する場合は、set クラスをグローバル名前空間にインポートしてください

var Set = sets.Set; // 将Set倒入到全局命名空间中
var s = new Set();  // 这样就不用加set前缀了

モジュールの規則 ファイルと名前空間は一致している必要があります。
たとえば、com.davidflanagan.collections.sets を使用するモジュールのファイルは com/davidflanagan/collections/sets.js にある必要があります。上記はパスです。

プライベート名前空間 関数

は、関数、プロパティ、クラス、メソッドなどの一部の API を他のユーザーが使用できるようにモジュールの外にエクスポートします。

モジュールの実装には、いくつかの補助関数とメソッドが必要です。
関数とメソッドはプライベート名前空間として表示されません。
関数スコープをプライベート名前空間、つまりモジュール関数として使用する

/*
 *    模块函数中的Set类
 *  时间:2018/07/22 13:15
 */

 // 声明全局变量Set, 使用一个函数返回值给其赋值
 // 函数结束后紧跟着圆括号,立即执行
 // 将其返回值赋值给Set
 // 这为函数表达式,没有创建函数变量
var Set = (function(){
    function Set() {    // 这个构造函数为局部变量
        this.values = {};    // 这个对象用来保存这个集合
        this.n = 0;    // 集合中的个数
        this.add.apply(this, arguments);    // 将所有的参数添加到集合中
    };

    // 给Set.prototype定义实例方法
    Set.prototype.contains = function(vale) {
        // 这里调用v2s
        return this.values.hasOwnProperty(v2s(value));
    };
    Set.prototype.size = function() {/*...*/}

    // 这里的为辅助函数和变量
    // 这里的变量不属于公有的api,但是都隐藏在函数的作用域内
    // 因此,不需要将其定义为Set属性,或使用下划线用来标识
    function v2s(val) {/*...*/};

    // 这个模块的共有api为Set()构造函数
    // 我们需要把这个函数从私有命名空间导出,以便在外部可使用,通过返回构造函数的方式导出
    // 它会变成构造函数所指的值
    return Set;
}());    // 定义函数后立即执行

js(名前空間)のモジュール解析

関連する推奨事項:

JavaScript の Object.defineProperty() メソッドの分析

js および object でのクラスの展開テクニカル分析指向

以上がjs(名前空間)のモジュール解析の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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