单例模式的定义是:保证一个类只有仅有一个实例,并提供一个访问它的全局访问点。
单例模式是一种经常使用的模式,有些对象咱们每每只须要一个,好比线程池,全局缓存,window对象。html
要实现一个单例模式并不复杂,无非是用一个变量来标志当前是否已经为某个类建立过对象,若是是,则在下一次获取该类的时候,直接返回以前建立的对象。缓存
var Singleton = function(name) { this.name = name this.instance = null } Singleton.prototype.getName = function() { alert(this.name) } Singleton.getInstance = function(name) { if (!this.instance) { this.instance = new Singleton(name) } return this.instance } var a = Singleton.getInstance('sven1') var b = Singleton.getInstance('sven2') alert(a===b) // true
经过Singleton.getInstance
来获取Singleton类的惟一对象,这种方式相对简单,但有问题,使用者并不知道这是一个单例类app
咱们如今的目标是实现一个透明的单例类,用户从这个类中获取对象的时候,能够像使用其余普通类同样。而且按照单一职责原则
,createDiv类实现功能,proxySingletonCreateDiv类管理单例管理单例模式,达到可组合的的效果this
// 建立普通类 var CreateDiv = function(html){ this.html = html this.init() } CreateDiv.prototype.init = function() { var div = document.createComment('div') div.innerHTML = this.html document.body.appendChild(div) } //引入代理类 var proxySingletonCreateDiv = (function() { var instance return function(html) { if (!instance) { instance = new CreateDiv(html) } return instance } })() var a = new proxySingletonCreateDiv('sven1') var b = new proxySingletonCreateDiv('sven2') alert(a===b) // true
分离建立实例对象
的职责与管理单例
的职责。下面用建立一个登录框举例prototype
// 管理单例 var getSingle = function(fn) { var result return function() { return result || (result= fn.apply(this, arguments)) } } var createLoginLayer = function() { var div = document.createElement('div') div.innerHTML = '我是登录浮窗' div.style.display = 'none' document.body.appendChild(div) return div } var createSingleLoginLayer = getSingle(createLoginLayer) document.getElementById('loginBtn').onclick = function(){ var loginLayer = createSingleLoginLayer() loginLayer.style.display = 'block' }
单例模式是一种简单但很是使用的技术,特别是惰性单例技术,在合适的时候才建立对象,而且至建立惟一的一个。更奇妙的是,建立对象和管理单例的职责被分布在两个不一样的方法中,这两个方法组合起来才具备单例模式的威力。线程