zoukankan      html  css  js  c++  java
  • Javascript单例模式

    1.简单单例模式:
    只能实例化一次的对象也就可以使用“对象字面量”的定义方式来实现:
    var singleton = {
        attribute:'',
        method:function(){}
    }
    这样定义的对象,不能使用new singleton的方式来生成另外的对象(不存在prototype和constructor属性)。


    2.包含私有成员的单例模式:
    如果看过之前的我写的关于类成员的文章,自然的我们就能想到用闭包来实现,既然要用的闭包,那么一定会用到函数和函数返回值,于是,这样的单例模式如下:
    var singleton = function(){
       var private_attribute = '';
       functioin private_method(){}
       return {
         public_attribute:'',
         public_method:function(){}
       };
    }
    还记得匿名函数吗?通常在使用闭包的时候会使用,改进之后如下:
    var singleton = (function(){
       var private_attribute = '';
       functioin private_method(){}
       return {
         public_attribute:'',
         public_method:function(){}
       };
    })();


    3.惰性加载(lazy loading,延迟加载)单例模式
    2,3中所示单例模式定义方式都是在定义时创建的单例,这样很浪费内存,如何能在使用的时候才创建(lazy loading,更多的用于图片的延迟加载)呢?所谓惰性加载,也就是先定义,然后在某个地方才创建对象,所以必须要使用函数,我们知道在java或者php中单例模式通常使用一个静态方法来创建,同理,我们再改进一下闭包形式的定义式:


    var singleton = (function(){
        var unique;
        function getinstance(){
            if(!unique){
                unique = construct();
                return unique;
            }
        }
        function construct(){
            var private_member;
            function private_method(){}
            return {//这里才是真正的单例对象
                public_member:'',
                public_method:function(){}
            };
    })();

  • 相关阅读:
    混合装置实现了24/7的能量收集和储存
    2020年人工智能汽车将出台多项标准
    自动驾驶汽车事故的责任追究
    多核处理器集成了神经处理单元
    广泛的信号处理链如何让语音助理“正常工作”
    先进机器人系统中的关键技术
    模拟内存计算如何解决边缘人工智能推理的功耗挑战
    TinyML设备设计的Arm内核
    获取url指定参数值(js/vue)
    js 实时监听textarea输入
  • 原文地址:https://www.cnblogs.com/lovefan/p/3891060.html
Copyright © 2011-2022 走看看