yiwei项目中Javascript的管理与维护

  • 命名空间(namespace):

    一个令开发人员头疼的问题就是如何防止函数名/类名和其他人的冲突,在一个公司内部项目组之间可以通过命名预定(比如加前缀等)解决这个问题。这问题在javascript开发中导致的后果会是很严重的,因为JS是解释执行的,如果后面定义了同名变量就会覆盖前面变量,并用应用新定义变量的语义,这在Js中合法,没有错误提示,因此bug很难找。
    目前,最新版本的JavaScript还是不支持命名空间,于是需要一套机制来模仿出命名空间的效果:

if($package)
{
    try {
        throw new Error("$package命名冲突!");
    } catch (e) {
        alert(e.name + ": " + e.message);
    }

}
var $package =function() {
    var a = arguments,
    o = null,
    i, j, d,rt;
    for(i=0; i<a.length; ++i) {
        d = a[i].split(".");
        rt = d[0];
        eval('if (typeof ' + rt + ' == "undefined"){' + rt + ' = {};} o = ' + rt + ';');
        for(j=1; j<d.length; ++j) {
            o[d[j]]=o[d[j]] || {};
            o=o[d[j]];
        }
    }
    return o;
};


$package("Yiwei.widget");

// Creating a class
Yiwei.widget.widgetName = new Class({
        options: {
                // options goes here
        },

        initialize: function(options) {
                this.setOptions(options);
                // initialize commands goes here
        }
});
Yiwei.widget.widgetName.implement(new Events); // Implements addEvent(type, fn), fireEvent(type, [args], delay) and removeEvent(type, fn)

Yiwei.widget.widgetName.implement(new Options);// Implements setOptions(defaults, options);

 

  • JS文件管理

    yiwei项目中将使用mootools这个第三方js库,所以需要有mootools.js和mootools-more.js这两个js文件,再加个base.js,用来存放一些公共js代码,然后每个功能模块分配一个JS文件,且以功能模块名为JS名。

  • 命名规则

    在base.js中定义类时,以yiwei.base.xxx形式,其中xxx表示你要定义的类名。
    在各个功能模块的js文件中定义类,则以yiwei.功能模块名.xxx的形式来命名。

  • Js代码压缩

    压缩工具选用yuicompressor-2.4.2。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值