前端设计模式之单例模式

Posted dangdanghepingping

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了前端设计模式之单例模式相关的知识,希望对你有一定的参考价值。

单例模式:构造函数每次创建对象,只有一个被创建.

单纯写个单例模式并不难,利用闭包,可以私有化变量.

 1 var single = (function(){
 2     var demo;
 3     return function(name){
 4         if(demo){
 5             return demo;
 6         }
 7         this.name = name;
 8         demo = this;
 9     }
10 })

 

 

但是想要把任何函数都变成单例模式的函数,需要利用一下工具函数:

function getSigleFn(fn){
    var result ;
    return function(){
        if(result){
            return result
        }
       result = fn.apply(this, arguments)//只有第一次执行;会走这里.这个arguements是指单例以后返回的函数的参数
       return result;
    }
}

这两个函数的写法总结:

1,都是利用了闭包保存要返回的值,并判断返回值有没有值,有就返回,没有就说明是第一次执行

2,始终要弄清楚你要的结果是啥,第一个要的是事例对象,第二个要的是一个新函数.

以上是关于前端设计模式之单例模式的主要内容,如果未能解决你的问题,请参考以下文章

前端设计模式之单例模式

设计模式之单例模式

设计模式之单例模式

Java设计模式之单例模式

设计模式之单例模式以及简单代码实现

设计模式之单例设计模式