美文网首页Web前端之路
JS设计模式1-单例模式

JS设计模式1-单例模式

作者: 卓三阳 | 来源:发表于2018-05-03 15:26 被阅读89次
什么是单例模式

单例模式也称作为单子模式,单体模式。单例模式的定义是产生一个类的唯一实例,是软件设计中较为简单但是很常用的一种设计模式。

单例模式的核心是确保只有一个实例,并提供全局访问


1.直接创建一个对象实现单例模式

既然我们只要一个实例,我们可以很容易想到,直接创建一个对象不就行了。

// 对象字面量
var Singleton = {
    attr1: 1,
    attr2: 2,
    method1: function(){
        return this.attr1;
    },
    method2: function(){
        return this.attr2;
    }
};

//对象变量
var div = document.body.appendChild( document.createElement( ''div' ) );

不足之处:
(1)没有什么封装性,所有的属性方法都是暴露的。
(2)全局变量很容易造成命名空间污染。
(3)对象一开始变创建,万一我们用不上就浪费了。


2.实现惰性单例(利用闭包和立即执行函数来实现)
// 实现单体模式创建div
var createDiv= (function(){
    var div;  
    return function(){
        if(!div) {
            div = document.createElement("div");
            div.style.width = '100px';
            div.style.height = '100px';
            div.style.background = '#e4e4e4';
            document.body.appendChild(div);
        }
        return div;
    }
})();

var div1=createDiv();
var div2=createDiv();
console.log(div1===div2); //true

虽然我们完成了惰性单例,但是我们同样发现了问题

  • 违反了单一职责原则,创建对象和管理单例放在了一个函数中createDiv
  • 如果我们还想创建一个其他的唯一对象,那就只能copy了

综上,我们需要 :
把不变的部分隔离出来,把可变的封装起来,这给予了我们扩展程序的能力,符合开放-封闭原则


3.抽离管理单例逻辑
<div id='test1' style="height:200px;background-color: #333"></div>
<div id='test2' style="height:200px;background-color: #e3e3e3"></div>

<script>
// 获取单个实例
var getInstance = function(fn) {
    var result;
    return function(){
        return result || (result = fn.call(this,arguments));
    }
};
  // 创建div
var createWindow = function(){
    var div = document.createElement("div");
    div.innerHTML = "i am #div";
    div.style.display = 'none';
    document.body.appendChild(div);
    return div;
};
// 创建iframe
var createIframe = function(){
    var iframe = document.createElement("iframe");
    document.body.appendChild(iframe);
    return iframe;
};
// 测试创建div
var createSingleDiv = getInstance(createWindow);  //返回一个闭包,result 为null
document.getElementById("test1").onclick = function(){
    var win = createSingleDiv();
    win.style.display = "block";
};
// 测试创建iframe
var createSingleIframe = getInstance(createIframe); //返回一个闭包,result 为null
document.getElementById("test2").onclick = function(){
    var win = createSingleIframe();
    win.src = "https://www.imooc.com";
};
</script>

getInstance函数将一个fn作为参数传递进去,如果有result这个实例的话,直接返回。否则的话,当前的调用fn这个函数,是this指针指向这个fn这个函数,之后返回被保存在result里面。


4.利用JS实现传统面向对象语言的单例模式

这是利用构造函数来完成实例创建的一种方式。大家可以参考下面这篇文章来学习。

JavaScript设计模式----单例模式


总结

单例模式是一种简单但非常实用的模式,特别是惰性单例技术,在合适的时候才创建对像,并且只创建唯一的一个。更奇妙的是,创建对象和管理单例的职责被分布在两个不同的方法中,这两个方法组合起来才具有单例模式的威力。
参考文章


【Javascript设计模式1】-单例模式
JS设计模式之单例模式
浅析JavaScript设计模式——单例模式

相关文章

  • 前端设计模式

    JS设计模式一:工厂模式jS设计模式二:单例模式JS设计模式三:模块模式JS设计模式四:代理模式JS设计模式五:职...

  • js常用设计模式11-状态模式

    js常用设计模式1-单例模式[https://www.jianshu.com/p/5cc2ca56a17b]js常...

  • js常用设计模式10-装饰者模式

    js常用设计模式1-单例模式[https://www.jianshu.com/p/5cc2ca56a17b]js常...

  • js常用设计模式9-中介者模式

    js常用设计模式1-单例模式[https://www.jianshu.com/p/5cc2ca56a17b]js常...

  • js常用设计模式8-职责链模式

    js常用设计模式1-单例模式[https://www.jianshu.com/p/5cc2ca56a17b]js常...

  • js常用设计模式7-享元模式

    js常用设计模式1-单例模式[https://www.jianshu.com/p/5cc2ca56a17b]js常...

  • 单例模式Java篇

    单例设计模式- 饿汉式 单例设计模式 - 懒汉式 单例设计模式 - 懒汉式 - 多线程并发 单例设计模式 - 懒汉...

  • JS设计模式1-单例模式

    什么是单例模式 单例模式也称作为单子模式,单体模式。单例模式的定义是产生一个类的唯一实例,是软件设计中较为简单但是...

  • python中OOP的单例

    目录 单例设计模式 __new__ 方法 Python 中的单例 01. 单例设计模式 设计模式设计模式 是 前人...

  • 单例

    目标 单例设计模式 __new__ 方法 Python 中的单例 01. 单例设计模式 设计模式设计模式 是 前人...

网友评论

    本文标题:JS设计模式1-单例模式

    本文链接:https://www.haomeiwen.com/subject/xdrkrftx.html