函数方法深入理解JavaScript系列阅读笔记(三):全面解析Module模式

文章结束给大家来个程序员笑话:[M]

    基本应用方法:在每次应用的时候都要new一下,即每一个实例都是内存中的一份copy。所以在没有穿参数或者没有其他特殊要求的情况下,可以在Module的前面直接加一个(),来实现自执行的目标,这样在内存中只会存在一份copy.

    定义匿名函数有两种方式:1. (function(){}());   2. (function(){})();

    在匿名函数中应用全局变量:将全局变量作为参数传递进匿名函数应用

(function ($, YAHOO) {
    // 这里,我们的代码就可以应用全局的jQuery对象了,YAHOO也是一样
} (jQuery, YAHOO));
在匿名函数中声明全局变量的方法:通过匿名函数的返回值来返回这个全局变量
var blogModule = (function () {
    var my = {}, privateName = "博客园";

    function privateAddTopic(data) {
        // 这里是内部处置代码
    }

    my.Name = privateName;
    my.AddTopic = function (data) {
        privateAddTopic(data);
    };

    return my;
} ());
上面例子声明白一个全局变量blogModule,该全局变量的值就是通过匿名函数的返回值返回的。

    

高级用法

    将module自身作为参数传入传入module函数可以实现将一个功能扩展到多个文件(应用之前必须要要先声明blogModule)。例:

    每日一道理
曾经辉煌过,曾经凋零过,这可是你至死不渝的生活吗?我亲爱的母亲—大自然。多少次,我伏在地上,去聆听你沉重的脉搏声;多少次,我伫立在山前,去感受那松涛千年的浩瀚。你的豪壮,足以让中华民族腾飞;你的无私,谱写了一曲曲感人至深的千古壮曲。
var blogModule = (function (my) {
    my.AddPhoto = function () {
        //添加内部代码  
    };
    return my;
} (blogModule));
 上例中的var不是一定要声明的。这个方法不能实现任意顺序的加载,因为实现这个方法的时候必须保障blogModule已存在。

    上面的方法可以实现任意加载顺序(这个时候必须要用var声明):

var blogModule = (function (my) {

    // 添加一些功能   
    
    return my;
} (blogModule || {}));  
因为最后传入的参数 blogModule || {} 保障了blogModule一定是存在的。这个语句的意思是:如果blogModule如果存在的话就应用blogModule作为参数参入,否则就将空对象作为参数传入。

    上面的两种方法只能实现添加属性或功能,并不能实现属性或功能的修改。

    紧耦合扩展可以实现修改一些属性和方法:

var blogModule = (function (my) {
    var oldAddPhotoMethod = my.AddPhoto;

    my.AddPhoto = function () {
        // 重载方法,依然可通过oldAddPhotoMethod调用旧的方法
    };

    return my;
} (blogModule));
module的克隆和继承

    要实现每一个文件匿名函数里的私有对象的交叉访问须要应用跨文件共享私有对象

 

 

文章结束给大家分享下程序员的一些笑话语录:  一边用着越狱的ip,一边拜乔帮主的果粉自以为是果粉,其实在乔帮主的眼里是不折不扣的叛徒。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值