JavaScript设计模式之单例模式原理与用法实例分析

  

本文实例讲述了JavaScript设计模式之单例模式原理与用法。分享给大家供大家参考,具体如下:

  

<强>单例模式的定义:强保证一个类仅有一个实例,并提供一个访问它的全局访问点。

  

单例模式是一种常用的模式,有些对象只需要一个,如线程池,全局缓存,浏览器中的窗口对象等,这时候可以用到单例模式。

  

单例模式典型的应用场景:单击按钮时,页面中会出现一个登陆浮窗,而该登录浮窗是唯一的,无论单击多少次按钮,这个浮窗都会被创建一次,则适合用单例模式创建。

  

全局变量不是单例模式,但在JavaScript开发中,经常会把全局变量当成单例来使用。

  

使用<代码> var={}; 这种方式创建对象时,对象一个是独一无二的,若变量一个被声明在全局作用域下,则可以在代码的任何位置使用这个变量。这显然满足单例模式的两个条件。

  

但是全局变量存在很多问题,很容易造成命名空间污染,如上面的<代码> var={}; 随时有可能被覆盖。

  

有必要尽量减少全局变量的使用,即使需要,也应该把它的污染降到最低。

  

  

<强> 1)使用命名空间

  

适当地使用命名空间,并不会杜绝全局变量,但可以减少全局变量的数量。

  

把a和b都定义为的属性,这样可以减少变量和全局作用域打交道的机会:

     ={var名称空间   答:函数(){   警报(“a”);   },   b:函数(){   alert (" b ");   }   };      之前      

<强>动态地创建命名空间:

        var obj={};   obj.namespace=function(名字){   var方法=name.split ('。');   var cur=obj;   我在技巧(var) {   如果(!坏蛋(建议[我]])   坏蛋(建议[我]]={};   坏蛋=cur[[我]]技巧;   }   };   obj.namespace('名称');   obj.namespace (“birth.year”);   console.dir (obj);      之前      

上述代码等价于:

        var obj={   名称:{},   出生:{   :{}   }   };      之前      

<强> 2)使用闭包封装私有变量

        var人=(函数(){   var_name=鞍鏊俊?   var _id=16;   返回{   getUserInfo:函数(){   返回_name +“:”+ _id;   }   }   })();      之前      

使用下划线来约定私有变量和,它们被封装在闭包产生的作用域中,外部是访问不到这两个变量的,这就避免了对全局的命令污染。

  

  

在需要的时候才创建对象实例。

        var createBox=(函数(){   var div;   返回函数(){   如果(div) {   div=document.createElement (div);   div.innerHTML='登录”;   div.style。显示='没有';   document.body.appendChild (div);   }   返回div;   }   })();   . getelementbyid (btn)。onclick=function () {   var盒=createBox ();   box.style。显示=翱椤?   };      之前      

用变量div来判断是否已经创建过浮窗。

  

<强>通用的惰性单例:

  

<强>问题:上面的惰性单例实例是违反单一职责原则的,创建对象和管理单例的逻辑都放在对象内部。若下次要创建页面中唯一的,需要把几乎照抄一遍。

        var createIframe=(函数(){   var iframe;   返回函数(){   如果(! iframe) {   iframe=document.createElement (iframe的);   document.body.appendChild (iframe);   返回iframe;   }   返回div;   }   })();      之前      

<>强解决:把不变的部分隔离出来,其实,管理单例的逻辑可以完全抽象出来,因为它们的逻辑是一样的:用一个变量来标记是否创建过对象,若是,则在下次直接返回已经创建好的对象。

        var createSingle=函数(函数){   var国旗;   返回国旗| |(国旗=函数。应用(这个参数));   };   var createBox=function () {   var div=document.createElement (div);   div.innerHTML='登录”;   div.style。显示='没有';   document.body.appendChild (div);   返回div;   };   . getelementbyid (btn)。onclick=function () {   var盒=createBox ();   box.style。显示=翱椤?   };   var createIframe=createSingle(函数(){   var iframe=document.createElement (iframe的);   document.body.appendChild (iframe);   返回iframe;   });   . getelementbyid (btn)。onclick=function () {   var iframe=createIframe ();   iframe.style。显示=翱椤?   };      

JavaScript设计模式之单例模式原理与用法实例分析