下面是 JavaScript Singleton 模式的一个非常流行的实现示例:
var mySingleton = (function() {
var instance;
function init() {
function privateMethod() {
console.log("I am private");
}
var privateVariable = "Im also private";
var privateRandomNumber = Math.random();
return {
publicMethod: function() {
console.log("The public can see me!");
},
publicProperty: "I am also public",
getRandomNumber: function() {
return privateRandomNumber;
}
};
};
return {
getInstance: function() {
if (!instance) {
instance = init();
}
return instance;
}
};
})();
我已经思考了一段时间,但当我们可以用这个简单的代码实现相同的结果时,我并没有真正理解这种复杂性的必要性:
singleton = (function() {
var obj = {
someMethod: function() {}
}
return obj;
}());
我在这里忽略了什么吗?
是的,在大多数情况下,您不需要这种复杂性,只需这样做
var singleton = {
someMethod: function() {}
};
然而,这种模式getSingleton
函数确实有一个优点:仅在调用函数(第一次)时才构造对象,而不是在实际需要对象之前构造对象。根据对象的复杂性,这可以提高程序的内存使用率和启动时间。它基本上是延迟加载模块。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)