欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  web前端

js的模块化分析(命名空间)

程序员文章站 2022-03-30 15:05:08
...
这篇文章给大家分享的内容是关于js的模块化分析(命名空间),有一定的参考价值,有需要的朋友可以参考一下。

代码组织到模块中,为了让代码根据模块化,即,不同场景中的模块复用。
模块是一个独立的js文件,模块文件可以包含一个类定义,一组相关的类,一个实用函数库,或者是一些待执行的代码。以模块形式编写代码,js代码段可以当做一个模块。
模块目标是支持程序开发,处理分散源中的代码组装,并且能让代码正确的执行

用作命名空间的对象

避免污染全局变量,使用一个对象作为命名空间,将函数的值和命名空间对象的属性存储起来,(即,通过全局变量来进行引用)

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

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

如果经常使用sets命名空间中的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中类的扩充及面向对象的技术解析

以上就是js的模块化分析(命名空间)的详细内容,更多请关注其它相关文章!

相关标签: javascript