Singleton单例模式详解

传送门:
JavaScript设计模式详解-单身狗的你来看看单例模式


单例模式

单例模式就是在创建一个新的实例时,会首先判断先前是否存在该实例,不存在则创建一个新实例并返回,否则返回之前的实例。

使用闭包实现单例模式

为什么使用闭包?

因为我们可以使用闭包来获取到当前实例的状态是已经创建还是尚未创建
比如

let getInstance = (function() {
  var instance = null;
  return function() {
    console.log(instance);
    if(!instance) {
      instance = 'created';
    }
    return instance;
  }
})();
getInstance(); // null
getInstance(); // created

上面这个例子很好地解释了使用闭包如何构造单例模式。
由于作用域链,在执行getInstance时首先会查找自己的作用域中是否存在instance,不存在则重新赋值,存在则直接返回。

惰性单例

什么是惰性?就是在需要时才创建。那么非惰性的概念就是不需要时也一直存在,通过其他方式显示和隐藏它。
有 惰性非单例, 非惰性非单例,惰性单例。这里主要说一下惰性单例模式。

let createDiv = (function() {
  let div;
  return function() {
    if(!div) {
      div = document.createElement('div');
      div.innerText = 'I\'m div';
      document.body.append(div);
    }
    return div;
  }
})();
createDiv();
createDiv();

就是上面的例子修改了一下,看的到不论执行多少次,都只创建一个div。
单例很好体现出来了,惰性则体现在其只有调用createDiv()时才会创建一个新实例。

职责分离的单例模式

有很多单例模式,但是集合在一起时,如果每次都一个个去判断是否存在实例是不是有些冗余?
于是出现了职责分离的单例模式,大概概念如下
这里写图片描述

代理器:

let getSingle = function(fn) {
  let result;
  return function() {
    console.log(result);
    if(!result) {
      result = fn.apply(this, arguments);
    }
    return result;
  }
}

div构造器:

let createDiv = function() {
  let div;
  div = document.createElement('div');
  div.innerText = 'text';
  document.body.append(div);
  return div;
}

Img构造器:

let createImg = function(src) {
  let oImg = document.createElement('img')
  document.body.appendChild(oImg)
  return oImg
}

创建各自的单例模式:

let createSingleDiv = getSingle(createDiv);
let createSingleImg = getSingle(createImg);

构造单例:

let div = createSingleDiv();
let div1 = createSingleDiv();
let img = createSingleImg();

你会发现,divdiv1是引用一样的实例的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值