当前位置: 首页 > 编程笔记 >

JavaScript设计模式之单件模式介绍

丁震博
2023-03-14
本文向大家介绍JavaScript设计模式之单件模式介绍,包括了JavaScript设计模式之单件模式介绍的使用技巧和注意事项,需要的朋友参考一下

单件模式说明

1. 说明:单件模式,就是静态化的访问中已经实例化的对象,这个对象只能通过一个唯一的入口访问,已经实例或待实例化的对象;面向对象语言如Java, .Net C#这样的服务端动态语言里,能保证类的操作有顺的进行,避免并行操作使数据发生混乱的情况;

2. 单件模式的好处:

1>. 减少 new 的操作,以免加快内存频繁操作,占用内存;
2>. 尽量减少大系统的对象的开销;
3>. 就是上面说的,可以保障某些类型的操作有顺序准确的操作,以免并行处理引起的数据异常现象;

当然上面说的好处,都是说服务端语言里的。在javascript这种弱类型的语言,不要纠结那么多,因为脚本都在自己的客户端这边操作的,没有什么操作冲突的问题;相当于整个服务器就你一个人在用,不用担心,你的数据会被其他什么人操作的问题;

实例源码



var Singleton = {

    instance: null,

    MailSender: function() {

        var self = this;

        self.to = '';

        self.title = "';

        self.content = "';

        self.send = function() {

             //send body

        }

    },

    getInstance : function() {

        if (this.instance == null) {

            this.instance = new Singleton.MailSender();

        }

        return this.instance;

    }

}

使用方法:



var mail = Singleton.getInstance();

mail.to = 'toname#mail.com';

mail.title = "单件模式发送";

mail.content = '发送内容';

mail.send();

当像有些全局框架,比如像 DWZ 这样的富UI框架,创建一个 全局 的Singleton 后,Singleton.instance 都有值了,就不必要再创建;

当然如果是写成这样的,会比较明了,跟服务端语言一置:



Singleton.getInstance().to = 'toname#mail.com';

Singleton.getInstance().title = "单件模式发送";

Singleton.getInstance().content = '发送内容';

Singleton.getInstance().send();

其他实说明

单件模式在什么的地方,比较有用呢?比如有一个操作服务器上一个统一的配置文件时,比如像大规模并发操作还需要注意先来后到的情况时,比如交易所的操作过程记录等,都可以用 单件模式 来操作;

另外:单件模式的方式:

1. 上头那种叫懒惰方式

2. 饿棍方式:


var Singleton = {

    instance : new Singleton.MailSender(),

    MailSender : function() {

      var self = this;

      self.to = '';

      self.title = "';

      self.content = "';

      self.send = function() {

          //send body

      }

   },

   getInstance : function() {

        return this.instance;

   }

}

使用方法一样;

使用闭包方式创建单件模式,隐藏 instance 对象

1. 代码:


var Singleton = (function() {

    var instance = null;

    function MailSender() {

       this.to = '';

       this.title = "';

       this.content = "';

    }

    MailSender.prototype.send = function() {

       //send body

    }

    return {

       getInstance : function() {

          if (instance == null) {

             instance = new MailSender();

          }

          return instance;

       }

    }

})();

2. 使用方法:


//一样用法

var mail = Singleton.getInstance();

mail.to = 'toname#mail.com';

mail.title = "闭包式 单件模式发送";

mail.content = '发送内容';

mail.send();


 类似资料:
  • 本文向大家介绍JavaScript设计模式之代理模式介绍,包括了JavaScript设计模式之代理模式介绍的使用技巧和注意事项,需要的朋友参考一下 代理模式说明 说明:顾名思义就是用一个类来代替另一个类来执行方法功能,这个模式跟装饰模式有点相似,不一样的是,代理模式是代替客户初始化被代理对象类,而装饰模式采用接口或初装饰者参数引用的方式来执行的。 在动态面向对象语言里,代理模式即起到控制修饰被代理

  • 本文向大家介绍JavaScript设计模式之外观模式介绍,包括了JavaScript设计模式之外观模式介绍的使用技巧和注意事项,需要的朋友参考一下 外观模式说明 说明:外观模式是用于由于子系统或程序组成较复杂而提供的一个高层界面接口,使用客户端更容易访问底层的程序或系统接口; 外观模式是我们经常使用遇到的模式,我们经常涉及到的功能,可能需要涉及到几个子接口或子系统,而我们的某个功能,可能只需要这向

  • 本文向大家介绍Java设计模式之单态模式(Singleton模式)介绍,包括了Java设计模式之单态模式(Singleton模式)介绍的使用技巧和注意事项,需要的朋友参考一下 定义:Singleton模式主要作用是保证在Java应用程序中,一个类Class只有一个实例存在。 在很多操作中,比如建立目录 数据库连接都需要这样的单线程操作。 还有,singleton能够被状态化;这样,多个单态类在一起

  • 本文向大家介绍JavaScript设计模式之建造者模式介绍,包括了JavaScript设计模式之建造者模式介绍的使用技巧和注意事项,需要的朋友参考一下 建造者模式说明 1. 将一个复杂对象的 构造 与它的表示相分离,使同样的创建过程可有不同的表示,这就叫做建造者模式。 2. 面向对象语言中的说明,主要角色: 1>. Builder 这个接口类,定义这个建造者[工人],统一的可操作的行为方式,它表示

  • 本文向大家介绍JavaScript设计模式之适配器模式介绍,包括了JavaScript设计模式之适配器模式介绍的使用技巧和注意事项,需要的朋友参考一下 适配器模式说明 说明: 适配器模式,一般是为要使用的接口,不符本应用或本系统使用,而需引入的中间适配层类或对象的情况; 场景: 就好比我们买了台手机,买回来后发现,充电线插头是三插头,但家里,只有两插头的口的插座,怎么办?为了方便,也有为能在任何地

  • 本文向大家介绍JavaScript设计模式之装饰者模式介绍,包括了JavaScript设计模式之装饰者模式介绍的使用技巧和注意事项,需要的朋友参考一下 装饰者模式说明 说明:通一个类来动态的对另一个类的功能对象进行前或后的修饰,给它辅加一些额外的功能; 这是对一个类对象功能的装饰,装饰的类跟被装饰的类,要求拥有相同的访问接口方法(功能),这在动态面向对象类里,一般以实现同一个接口(interfac