首页 > 代码库 > Javascript单例模式

Javascript单例模式

1.简单单例模式:
只能实例化一次的对象也就可以使用“对象字面量”的定义方式来实现:
var singleton = {
    attribute:‘‘,
    method:function(){}
}
这样定义的对象,不能使用new singleton的方式来生成另外的对象(不存在prototype和constructor属性)。


2.包含私有成员的单例模式:
如果看过之前的我写的关于类成员的文章,自然的我们就能想到用闭包来实现,既然要用的闭包,那么一定会用到函数和函数返回值,于是,这样的单例模式如下:
var singleton = function(){
   var private_attribute = ‘‘;
   functioin private_method(){}
   return {
     public_attribute:‘‘,
     public_method:function(){}
   };
}
还记得匿名函数吗?通常在使用闭包的时候会使用,改进之后如下:
var singleton = (function(){
   var private_attribute = ‘‘;
   functioin private_method(){}
   return {
     public_attribute:‘‘,
     public_method:function(){}
   };
})();


3.惰性加载(lazy loading,延迟加载)单例模式
2,3中所示单例模式定义方式都是在定义时创建的单例,这样很浪费内存,如何能在使用的时候才创建(lazy loading,更多的用于图片的延迟加载)呢?所谓惰性加载,也就是先定义,然后在某个地方才创建对象,所以必须要使用函数,我们知道在java或者php中单例模式通常使用一个静态方法来创建,同理,我们再改进一下闭包形式的定义式:


var singleton = (function(){
    var unique;
    function getinstance(){
        if(!unique){
            unique = construct();
            return unique;
        }
    }
    function construct(){
        var private_member;
        function private_method(){}
        return {//这里才是真正的单例对象
            public_member:‘‘,
            public_method:function(){}
        };
})();