JavaScript 设计模式之单例模式
单例模式的意思是只需要实例化某个类一次,它的方法也比较简单,通过判断某个类是否已经被实例化了,再返回该值。可以通过各种方法来实现单例模式,下面我们采取以下这种实现方式:
var single = (function(window, undefined) {
var _u;//私有成员,
var newModel = function() {//需要创建的类
this.a = 'i am a';
this.b = 'i am b';
this.hello = 'i am a single Model';
}
newModel.prototype = {//原型扩展
constructor : newModel,
a : function() {
console.log(a);
},
b : function() {
console.log(b);
},
hello : function() {
console.log(this.hello);
}
}
return {
createSingleModule : function() {//暴露共有方法
return (_u || (_u = new newModel()));//如果该类实例过了,就返回。没有则重新实例化。
}
}
})(window, undefined);
通过以上代码,我们简单地实现了该模式。在实际情况中,我们可能会需要创建一个组件,这个组件是唯一一个,比如遮盖背景。在这样的情况下采用单例模式是非常明智的选择。
在使用单例的模式我们可以考虑一下几点,以帮助你判断是否应该采用此模式构建你的项目:
- 当类只能由一个实例,并且它很容易从公共访问点对它进行访问时候。
- 该类的实例是可以通过子类化进行扩展的,并且客户无需更改代码就能使用一个扩展的实例的时候。
//创建一个单例的实例化对象,不管此函数执行多少次,
// 返回的对象总是同一个。newModel只会被实例化一次。
single.createSingleModule();
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论