一,整体概要javascript
1,笔者浅谈html
顾名思义单例模式并不难理解,是产生一个类的惟一实例,在咱们实际开发中也会使用到这种模式,它属于建立模式的一种,基于JS语言自己的语法特征,前端
对象直接量“{}”,也能够做为单例模式的一种表现形式,以下代码参考java
1 function Foo(){ 2 this.bar = "Hello Singleton !" ; 3 } ; 4 var Singleton = { 5 instance : null , 6 getInstance : function(){ 7 if(!this.instance){ 8 this.instance = new Foo() ; 9 } 10 return this.instance ; 11 } 12 } ;
就像这样当咱们每次调用 Singleton.getInstance()时,就会获得惟一的实例。设计模式
单例模式是javascript最基本,最有用的模式之一,它提供了一种将代码组织为一个逻辑单元的手段,这个逻辑单元中的代码经过单一的变量进行访问。浏览器
单体在javascipt中有许多用处,能够用来划分命名空间,以减小全局变量的泛滥。还能够用在分支技术中用来处理各浏览器的差别。然咱们再看几个例子(*^__^*) 缓存
1 var Singleton = (function(){
var instance = null ; 2 function Foo(){ 3 this.bar = "Hello Singleton !" ; 4 } ; 5 return{ 6 getInstance : function(){ 7 if(!instance){ 8 instance = new Foo() ; 9 } 10 return instance ; 11 } 12 } ; 13 })() ;
这是经过模块模式实现的。前端框架
1 var Singleton = (function(){
var instance = null ; 2 function Foo(){ 3 this.bar = "Hello Singleton !" ; 4 } ; 5 function createInstance(){ 6 return new Foo() ; 7 } ; 8 return{ 9 getInstance : function(){ 10 if(!instance){ 11 instance = createInstance() ; 12 } 13 return instance ; 14 } 15 } ; 16 })() ;
这是结合工厂模式实现的单例方式。框架
单例模式是设计模式中最简单的形式之一。这一模式的目的是使得类的一个对象成为系统中的惟一实例。要实现这一点,能够从客户端对其进行实例化开始。所以须要用一种只容许生成对象类的惟一实例的机制,“阻止”全部想要生成对象的访问。使用工厂方法来限制实例化过程。这个方法应该是静态方法(类方法),由于让类的实例去生成另外一个惟一实例毫无心义。函数
二,源码案例参考
咱们拿Bootstrap前端框架做为实例进行讲解,如下说的是"alert.js v3.3.1"中的源码,以下所示
这一这句代码,“if (!data) $this.data('bs.alert', (data = new Alert(this)))” 这就是单例的方式建立组件的实例对象,经过查找缓存在DOM节点的对象判断是否建立实例。
再给你们几个例子巩固单例模式的组织方式以及如何使用
再看一个,这属于惰性加载。
三,案例引入
今天咱们将结合单例模式与工厂模式作一个小例子,以理解为主。
(1),建立单例类
1 var Singleton = (function(){ 2 var instance = null ; 3 function createInstance(type){ 4 return factory.create(type) ; 5 } ; 6 return{ 7 getInstance : function(type){ 8 if(!instance){ 9 instance = createInstance(type) ; 10 } 11 return instance ; 12 } 13 } ; 14 })() ;
(2),建立工厂类
1 var factory = (function(){ 2 var instanceVendor = { 3 "foo" : function(){ 4 return new Foo() ; 5 } , 6 "zoo" : function(){ 7 return new Zoo() ; 8 } 9 } ; 10 return { 11 create : function(type){ 12 return instanceVendor[type]() ; 13 } 14 } ; 15 })() ;
(3),建立实体对象类
1 function Foo(){ 2 this.bar = "Hello Singleton !" ; 3 this.getBar = function(){ 4 return this.bar ; 5 } ; 6 } ;
(4),建立客户端测试类
1 function SingleClient(){ 2 this.run = function(){ 3 Singleton.getInstance("foo").getBar() ; // Hello Singleton ! 4 } ; 5 } ;
四,总结一下