设计模式之单体模式

“Hello world”

“单体模式是Javascript中最基本但有最有用的设计模式之一,它可能比其他任何模式都常用。” --出自《Javascript设计模式》

简单的单体模式,是对数据的单体特征、行为的简单封装,非常常用。这种模式提供了一种将代码组织为一个逻辑单元的手段,这个逻辑单元中的代码可以通过单一的变量进行访问。通过确保单体对象只存在一份实例,你就可以确信自己的所有代码使用的都是同样的全局资源。

/* singleton */

缺点:1、容易被别的开发者进行同名方法覆盖,容易混淆对象(污染环境)(在不使用命名空间的情况下

var Singleton = {
    attr1: 'YaDu',
    attr2: 23,
    methods1: function() {
        // TODO
     },
    methods2: function() {
        // TODO
     }
}

/* closure */

 

闭包单体。其中闭包的主要目的是用来保护数据

var Duya = {}
Duya.Singleton = (function() {
    let _data = 1;
    function _method1() {
        // TODO
     }

    return {
          num:  _data,
          total: _method1,
          method: function() {
                return  '22'
          }           
     }
})()

// 惰性

自我理解:建造基础单体的基础上 ,建立getInstance函数,使得数据在需要用的时候调用

var Duya = {}
Duya.Singleton = (function() {
    let _data = 1;
    let method= null;

    function _method1() {
        // TODO
     }
    
    function constructor() {
        // TODO
     }

    return {
          getInstance: function() {
              if(!method) {
                method = constructor()
             }
              return method
          }        
     }
})()

// 分支单体

var Duya = {}
Duya.Singleton  = (function() {
    // 这里只是举栗子,具体情况是开发环境而定
    const def = false
    const A = {

     };
    const B = {

     }
    return (def) ? A : B
})()

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值