javascript中Singleton设计模式的实现

本文介绍如何利用JavaScript的闭包特性来实现Singleton模式,通过定义静态全局变量、匿名类、私有属性及其操作方法和公共接口,展示在HTML5电气原理图绘制项目中使用Singleton模式存放原点坐标、屏幕尺寸等信息的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

众所周知,javascript是动态语言,而Singleton模式在动态语言中实现是比较困难的,不过可以利用javascript的闭包特性来实现Singleton模式。例如在我们HTML5电气原理图绘制项目中,需要一个Singleton来存放原点坐标、屏幕尺寸等信息,可以通过如下代码实现:

var gs_graph = new(
    function(){
         this.publicMethod = function(){
			console.log("run publicMethod...");
			privateMethod();
		}
        this.getOrgX = function(){
			return m_orgX;
		}
        this.setOrgX = function(orgX){
			m_orgX = orgX;
		}
        var m_orgX = 101; // 私有属性;
		var privateMethod = function(){
			console.log("run privateMethod...");
		}
     }
)();
在上面的代码中,首先定义了一个静态全局变量,在()中通过function定义了一个匿名类,同时定义的私有属性m_orgX,以及该属性的get/set方法,同时定义了公共接口,privateMethod为私有方法。new代表生成一个这个类的实例。


from:http://blog.csdn.net/yt7589/article/details/6671159

from:http://kb.cnblogs.com/page/97011/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值