javascript 单例/单体模式(Singleton)


Posted in Javascript onApril 07, 2011

单例模式的三个特点:
1,该类只有一个实例
2,该类自行创建该实例(在该类内部创建自身的实例对象)
3,向整个系统公开这个实例接口
Java中大概是这个样子

class Singleton { 
//私有,静态的类自身实例 
private static Singleton instance = new Singleton(); 
//私有的构造子(构造器,构造函数,构造方法) 
private Singleton(){} 
//公开,静态的工厂方法 
public static Singleton getInstance() { 
return instance; 
} 
}

使用时
Singleton obj = Singleton.getInstance();

这个单例类在自身被加载时instance会被实例化,即便加载器是静态的。因此,对于资源密集,配置开销较大的单体更合理的做法是将实例化(new)推迟到使用它的时候。即惰性加载(Lazy loading),它常用于那些必须加载大量数据的单体。修改下
class LazySingleton { 
//初始为null,暂不实例化 
private static LazySingleton instance = null; 
//私有的构造子(构造器,构造函数,构造方法) 
private LazySingleton(){} 
//公开,静态的工厂方法,需要使用时才去创建该单体 
public static LazySingleton getInstance() { 
if( instance == null ) { 
instance = new LazySingleton(); 
} 
return instance; 
} 
}

使用方式同上。
单例模式是Javascript最基本,最有用的模式之一。它提供了一种将代码组织为一个逻辑单元的手段,这个逻辑单元中的代码通过单一的变量进行访问。
单体在Javascipt中有许多用处,可以用来划分命名空间,以减少全局变量的泛滥。还可以用在分支技术中用来处理各浏览器的差异。
Javascript中单例模式的实现方式有多种,每一种都有自身的优点或缺点。
1,对象直接量实现最基本,最简单的单体
var Singleton = { 
attr1 : 1, 
attr2 : 'hello', 
method1 : function(){alert(this.attr2);}, 
method2 : function(arg){} 
}

这种方式中,对象所有成员都通过Singleton加点号访问。所有成员是公开的,没有私有的。在执行到变量Singleton时,会加载(实例化)自身,即非惰性加载。
此外method1用this访问单体的其它成员会存在一些风险,因为method1的上下文不是总是指向Singleton对象。
比如当把method1作为事件监听器时,this可能指向的是dom元素,这时可能会提示undefined。
2,闭包实现私有成员的单体
var Singleton = function(){ 
var attr = 1, fn = function(){}; 
return { 
method : function(){ fn(); }, 
getAttr : function(){ return attr; } 
}; 
}();

这种方式中var定义私有的成员属性attr,方法fn,然后返回一个公开的接口method和getAttr。今后修改实现时,接口方法method和getAttr不变,只需修改私有的attr和fn的具体实现。使用如下
Singleton.method(); 
Singleton.getAttr();

3,闭包实现私有成员的惰性实例化单体
var LazySingleton = function(){ 
var attr = 1, fn = function(){}; 
var obj = { 
method : function(){ fn(); }, 
getAttr : function(){ return attr; } 
}; 
function init(){ 
return obj; 
} 
return {getInstace: init}; 
}();

适用场合上面已经提到:对于那些必须加载大量数据的单体直到需要使用它的时候才实例化。使用方式是这样的
LazySingleton.getInstance().method(); 
LazySingleton.getInstance().getAttr();
Javascript 相关文章推荐
javascript 密码强弱度检测万能插件
Feb 25 Javascript
javascript中substr,substring,slice.splice的区别说明
Nov 25 Javascript
面向对象的Javascript之三(封装和信息隐藏)
Jan 27 Javascript
JavaScript函数节流概念与用法实例详解
Jun 20 Javascript
javascript中获取元素标签中间的内容的实现方法
Oct 08 Javascript
JavaScript实现256色转灰度图
Feb 22 Javascript
JS判断微信扫码的方法
Aug 07 Javascript
浅谈JS 数字和字符串之间相互转化的纠纷
Oct 20 Javascript
Mac中安装nvm的教程分享
Dec 11 Javascript
详解swipe使用及竖屏页面滚动方法
Jun 28 Javascript
JS的Ajax与后端交互数据的实例
Aug 08 Javascript
Node.js API详解之 net模块实例分析
May 18 Javascript
Safari5中alert的无限循环BUG
Apr 07 #Javascript
JQuery中html()方法使用不当带来的陷阱
Apr 07 #Javascript
仅IE6/7/8中innerHTML返回值忽略英文空格的问题
Apr 07 #Javascript
jQuery为iframe的body添加click事件的实现代码
Apr 07 #Javascript
JQUERY的属性选择符和自定义选择符使用方法(二)
Apr 07 #Javascript
Jquery Ajax的Get方式时需要注意URL地方
Apr 07 #Javascript
jquery对表单操作2
Apr 06 #Javascript
You might like
中国站长站 For Dede4.0 采集规则
2007/05/27 PHP
PHP调用Webservice实例代码
2011/07/29 PHP
Zend Studio去除编辑器的语法警告设置方法
2012/10/24 PHP
解析phpstorm + xdebug 远程断点调试
2013/06/20 PHP
分享8个最佳的代码片段在线测试网站
2013/06/29 PHP
php之curl实现http与https请求的方法
2014/10/21 PHP
Yii框架实现邮箱激活的方法【数字签名】
2016/10/18 PHP
PHP常用函数总结(180多个)
2016/12/25 PHP
Ajax+PHP实现的分类列表框功能示例
2019/02/11 PHP
js实现checkbox全选和反选示例
2014/05/01 Javascript
JS实现可缩放、拖动、关闭和最小化的浮动窗口完整实例
2015/03/04 Javascript
javascript的 {} 语句块详解
2016/02/27 Javascript
noty ? jQuery通知插件全面解析
2016/05/18 Javascript
详解JavaScript中的事件流和事件处理程序
2016/05/20 Javascript
NodeJS实现客户端js加密
2017/01/09 NodeJs
Vue.js中extend选项和delimiters选项的比较
2017/07/17 Javascript
AngularJS select加载数据选中默认值的方法
2018/02/28 Javascript
Vue中的验证登录状态的实现方法
2019/03/09 Javascript
javascript移动端 电子书 翻页效果实现代码
2019/09/07 Javascript
Javascript异步编程async实现过程详解
2020/04/02 Javascript
JS async 函数的含义和用法实例总结
2020/04/08 Javascript
基于JavaScript实现简单扫雷游戏
2021/01/02 Javascript
Python字符串拼接、截取及替换方法总结分析
2016/04/13 Python
STUBHUB日本:购买和出售全球活动门票
2018/07/01 全球购物
高校辅导员推荐信范文
2013/12/25 职场文书
业务部主管岗位职责
2014/01/29 职场文书
信息技术教学反思
2014/02/12 职场文书
鸿星尔克广告词
2014/03/21 职场文书
企业标语口号
2014/06/10 职场文书
2015年教师节贺卡寄语
2015/03/24 职场文书
七年级上册生物的课件
2019/08/07 职场文书
Go语言中break label与goto label的区别
2021/04/28 Golang
alibaba seata服务端具体实现
2022/02/24 Java/Android
使用Python获取字典键对应值的方法
2022/04/26 Python
Python first-order-model实现让照片动起来
2022/06/25 Python
Windows server 2016服务器基本设置
2022/08/14 Servers