单例模式【javascript设计模式】

学而时习之,不亦说乎?——孔丘《论语•学而》

单例模式的核心在于:** 确保一个实例,并提供全局访问。 **


首先,单例模式要求只有一个实例,其次这个实例在全局都可以访问到。比如我在实习的时候写的这个页面:


Paste_Image.png

点击* 邮件获取最新安装包 *的时候会弹出这个框框,很显然,这个框框只需要被创建一次即可,所以我们可以写下如下的代码:

// html
        <button class="J-popup">btn</button>
// js
        var popup = (function () {
            var div = document.createElement('div');
            div.innerHTML = '我是一个框框';
            div.style.display = 'none';
            document.body.appendChild(div);
            return div;
        })();

        document.getElementsByTagName('J-popup').onclick = function () {
            popup.style.display = 'block';
        }

这种方式虽然符合单例模式的定义,但是也许我们进入这个页面的时候不会去点这个获取安装包的按钮,那么这个dom节点就被白白浪费了,所以改为惰性创建,修改后的代码如下:

      var popup = (function () {
            var div;
            return function () {
                if (!div) {
                    div = document.createElement('div');
                    div.innerHTML = '我是一个框框';
                    div.style.display = 'none';
                    document.body.appendChild(div);
                }
                return div;
            }
        })();

        document.getElementsByTagName('J-popup').onclick = function () {
            var popupInstance = popup();
            popupInstance.style.display = 'block';
        }

ok,到这里来说已经是一个比较完美的单例的实践了,但是以上的代码违反了单一职责的原则,这就导致了一个问题:比如要是我需要在创建另一个不同于div的框框,诸如iframe之类的,还需要将popup这个函数重新复制一份然后改一下内部的代码,** don't repeat you self !!! **
分析一下就会发现原因在于我们把创建对象和管理对象的逻辑都放在了popup函数里了,所以我们要做的仅仅是将它们分离开来:

// 定义一个生成单例对象的函数:
        var getSingle = function (fn) {
            var instance;
            return function () {
                return instance || ( instance = fn.apply(this, arguments) );
            }
        }

现在就可以愉快的创建单例了,比如上面的那个弹框,可以这样子:

       var popup = function () {
           var div = document.createElement('div');
           div.innerHTML = '我是一个框框';
           div.style.display = 'none';
           document.body.appendChild(div);
           return div;
       };

       var popupFactory = getSingle(popup);

       document.getElementsByTagName('J-popup').onclick = function () {
           var popupInstance = popupFactory();
           popupInstance.style.display = 'block';
       }

要是想创建其他的单例,只用复写popup,然后丢给getSingle就OK啦。


到这里突然想到,实习第一个需求是写一个设计师管理的页面,可以简化成一个通过ajax动态往页面列表里面追加数据的模型,列表的每个item需要添加click事件,在用事件代理的前提下,click事件只需要在第一次渲染列表的时候被绑定一次即可。但是我们不想去判断当前是否第一次渲染列表怎么办,如果借助于jquery,可以给节点绑定one事件:

       var bindEvent = function () {
           $('.list').one('click', function () {
               console.log('click');
           });
       }
       var render = function () {
           console.log('渲染列表');
           bindEvent();
       }
       render();
       render();
       ......

借助我们刚从实现的getSingle()函数也可以达到同样的效果:

      var bindEvent = getSingle(function () {
           document.getElementsByTagName('list')[0].onClick = function () {
               console.log('click');
           }
           return true;
       });
       var render = function () {
           console.log('渲染列表');
           bindEvent();
       }
       render();
       render();
       ......

ok,就这些啦,明天晚上继续撸** 策略模式 **欢迎小伙伴们一起交流_

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,393评论 5 467
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,790评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,391评论 0 330
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,703评论 1 270
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,613评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,003评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,507评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,158评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,300评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,256评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,274评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,984评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,569评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,662评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,899评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,268评论 2 345
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,840评论 2 339

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,561评论 18 139
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,259评论 25 707
  • 单例模式(SingletonPattern)一般被认为是最简单、最易理解的设计模式,也因为它的简洁易懂,是项目中最...
    成热了阅读 4,213评论 4 34
  • 吴军博士的《智能时代》,这是我读吴军博士的第六本书了,非常适合大学计算机,软件和信息专业的同学读,当然喜欢阅读...
    离开我的西海岸阅读 656评论 0 3
  • 女人的脸,六月的天,说变就变。尤其是中年的女人,在家里表现得更加突出。因为在家里是相对隐蔽的空间,或者家里有可...
    天凉好个秋吖阅读 309评论 0 2