zoukankan      html  css  js  c++  java
  • 模块模式

    前面的模式是用于为自定义类型创建私有变量和特权方法的。而道格拉斯所说的模块模式则是为单例创建私有变量和特权方法。所谓单例,值得就是只有一个实例的对象。按照惯例,Javascript是以对象字面量的方式来创建单例对象的。

    var singleton = {
        name:value,
        method:function(){
            // 这里是方法的代码 
        }
    }

    模块模式通过为单例添加私有变量和特权方法能够使其得到增强,其语法形式如下:

    var singleton = function (){
        // 私有变量和私有函数
        var privateVariable = 10;
        function privateFunction(){
            return false;
        }
        // 特权/公有方法和属性
        return {
            publicProperty:true,
            publicMethod:function(){
                privateVariable++;
                return privateFunction();
            }
        };
    }();

    这个模块模式使用了一个返回对象的匿名函数。在这个匿名函数内部,首先定义了私有变量和函数。然后,将一个对象字面量最为函数的值返回。返回的对象字面量中只包含可以公开的属性和方法。由于这个对象是在匿名函数内部定义的,因此它的公有方法有权访问私有变量和函数。从本质上来讲,这个对象字面量定义的是单例的公共接口。这种模式在需要对单例进行某些初始化,同时又需要维护其私有变量时时非常有用的,例如:

    var application = function(){
        // 私有变量和函数
        var components = new Array();
        //初始化
        components.push(new BaseComponent());
        //公共
        return {
            getComponentCount: function(){
                return components.length;
            },
            registerComponent:function(component){
                if(typeof component == "object"){
                    components.push(component);
                }
            }
        };
    }()

    在web应用程序中,经常需要使用一个单例来管理应用程序级的信息。这个简单的例子创建了一个用于管理组件的application对象。在创建这个对象的过程中,首先声明了一个私有的components数组,并向数组中添加了一个BaseComponent的新实例(在这里不需要关心BaseComponent的代码,我们只是用它来展示初始化操作)。而返回对象的getComponentCount()和registerComponent()方法,都是有权访问数组components的特权方法。前者只是返回已注册的组件数目,后者用于注册新组件。

    简言之,如果必须创建一个对象并以某些数据对其进行初始化,同时还要公开一些能够访问这些私有数据的方法,那么久可以使用模块模式。以这种模式创建的每个单例都是object的实例,因为最终要通过一个对象字面量来表示他。事实上,这也没有什么;毕竟,单例通常都是作为全局对象存在的,我们不会将它传递给一个函数。因此,也就没有什么必要使用instanceof操作符来检查其对象类型了。

  • 相关阅读:
    mysql grant命令
    appache ab测试高并发
    转:windows下定时执行备份数据库
    linux设置定时任务
    YII学习总结6(模板替换和“拼合”)
    YII学习总结5(视图)
    YII学习总结4(cookie操作)
    把字符串转换成整数
    不用加减乘除做加法
    求1+2+3+4+...+n
  • 原文地址:https://www.cnblogs.com/lvruifang/p/7283134.html
Copyright © 2011-2022 走看看