首页 » 编写高质量代码:改善JavaScript程序的188个建议 » 编写高质量代码:改善JavaScript程序的188个建议全文在线阅读

《编写高质量代码:改善JavaScript程序的188个建议》建议70:惰性实例化

关灯直达底部

惰性实例化要解决的问题是:避免了在页面中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,这样调用方式就发生了一点改变。