• javascript中的设计模式之单例模式


    一、定义

    保证一个类仅有一个实例,并提供一个访问它的全局访问点

    二、举例

    单击按键弹出弹出框,这个弹出框是唯一的,无论单击多少次,这个弹出框都应该只被创建一次。

    三、实现

    单例模式分为两种,一种是立即执行,另一种是惰性执行

    1.立即执行

    所谓立即执行就是当js代码加载后,就会立刻创建一个单例对象。

    那么根据单例模式的定义,我们在全局环境下声明变量: var a = {},或者是直接创建一个对象实例:var person = new Person()。这是变量对象这是不是单例模式呢?事实上全局变量不是到单例模式,但是在开发中,我们常常会把全局变量当成单例来使用。所以就作为了一种实现方式。比如著名的jquery,在浏览器将jquery文件下载后,就会立即执行并创建一个jquery对象。

     

     

    2.惰性单例

    所谓惰性单例,就是只有在需要时才创建单例对象。这种方式是我们最常用的,而且通常是引入了缓存代理模式(后面会有)来实现。实现代码如下:

    // 创建单例对象方法
    function singleton(fn){
        var instance = null;
        return function(){
            if(instance){
                return instance;
            }else{
                instance = fn.apply(this,arguments);
                return instance;
            }
        }
    }
    
    function Person(name){
        this.name = name;
    }
    Person.prototype.display = function(){
        console.log(this.name);
    };
    
    var singleName = singleton(function(name){
        return new Person(name);
    });
    var p1 = singleName("jyy");
    p1.display();   // jyy
    var p2 = singleName("fdf");
    p2.display();   // jyy

    代码中可以看到使用创建单例对象的精髓在于缓存代理模式,因此需要记住这个方法,在实际开发中经常用也很好用。 

  • 相关阅读:
    关于使用easyui dataGrid遇到的小bug问题
    构造带清除按钮的combo
    ajax方式提交数据时“+”的处理
    JavaScript call方法
    stackoverflow上的一个关于传递类对象的问题
    经典回溯算法(八皇后问题)
    c++构造函数(初始化式)被忽略的东西
    跟着<<C++Primer 学set容器>>
    排序算法(内部排序)总结
    hosts文件无法修改的问题解决方案
  • 原文地址:https://www.cnblogs.com/jyybeam/p/13341071.html
Copyright © 2020-2023  润新知