惰性实例化要解决的问题是:避免了在页面中JavaScript初始化执行的时候就实例化类,如果在页面中没有使用这个实例化的对象,就会造成一定的内存浪费和性能消耗。如果将一些类的实例化推迟到需要使用它的时候才去做,就可以避免资源过早损耗,做到“按需供应”。
var myNamespace=function{
var Configure=function{
var privateName="someone's name";
var privateReturnName=function{
return privateName;
}
var privateSetName=function(name){
privateName=name;
}
//返回单例对象
return{
setName:function(name){
privateSetName(name);
},
getName:function{
return privateReturnName;
}
}
}
//存储configure实例
var instance;
return{
getInstance:function{
if(!instance){
instance=Configure;
}
return instance;
}
}
};
//使用方法上需要getInstance这个函数作为中间量
myNamespace.getInstance.getName;
上面就是简单的惰性实例化的示例,其中有一个缺点就是需要使用中间量来调用内部的Configure函数所返回的对象的方法,当然也可以使用变量来存储myNamespace.getInstance返回的实例对象。将上面的代码稍微修改一下,就可以用比较直观的方法来使用内部的方法和属性。
//惰性实例化的变体
var myNamespace2=function{
var Configure=function{
var privateName="someone's name";
var privateReturnName=function{
return privateName;
}
var privateSetName=function(name){
privateName=name;
}
//返回单例对象
return{
setName:function(name){
privateSetName(name);
},
getName:function{
return privateReturnName;
}
}
}
//存储configure实例
var instance;
return{
init:function{
//如果不存在实例,就创建单例实例
if(!instance){
instance=Configure;
}
//创建Configure单例
for(var key in instance){
if(instance.hasOwnProperty(key)){
this[key]=instance[key];
}
}
this.init=null;
return this;
}
}
};
//使用方式
myNamespace2.init;
myNamespace2.getName;
在上面代码中修改了自执行函数返回的对象的代码,在获取Configure函数返回的对象时,将该对象的方法赋给myNamespace2,这样调用方式就发生了一点改变。