Javascript单例模式概念与实例

前言

和其余编程语言同样,Javascript一样拥有着不少种设计模式,好比单例模式、代理模式、观察者模式等,熟练运用Javascript的设计模式可使咱们的代码逻辑更加清晰,而且更加易于维护和重构。javascript

本文将介绍Javascript模式中较为常见和实用的模式——单例模式,主要分为概念和实例部分。在介绍实例的同时也会对代码中额外的知识点进行讲解。html

单例模式概念

首先什么是单例模式?能够这样理解:单例模式旨在保证一个类仅有一个实例,并提供一个全局的访问点。java

可能有人仍是不太理解单例的概念,那么你能够想象生活中的一些例子。好比注册帐号的时候,若是咱们注册的帐号已经存在,那么系统会提示咱们“帐号已经存在是否使用该帐号登录”,咱们没法再次建立一个如出一辙的帐号,除非把原帐号注销。这就是单例模式的生动体现。git

相似的例子还有网页上的登录弹框,不管咱们点击多少次登录按钮,界面上始终只会显示一个登录弹框,没法再建立第二个。github

本文就将以登录弹框为例介绍单例模式的使用方式。编程

单例模式实例

1.demo展现

弹框实例

演示地址为:弹框实例设计模式

2.代码展现

构建单例模式弹框实例的代码每一个人可能写的都不同,可是目的都是一个:构建一个全局惟一并可访问的弹框。接下来咱们一步一步来实现这个例子。闭包

(1)获取DOM对象app

var $ = function(id) {
    return typeof id === 'string' ? document.getElementById(id) : id; 
};复制代码

首先为了便于以后关于DOM的一些操做,咱们这里利用函数式编程的原理将获取目标id的元素对象方法封装了一下,直接利用$(id)就能够获取。编程语言

(2)弹框构造函数

var Modal = function(id, html) {
    this.html = html;
    this.id = id;
    this.open = false;
};复制代码

这里咱们声明了一个Modal做为弹框的构造函数,而且再其内部定义了公有属性html、id和open。html用来定义弹框内部的内容,id用来给弹框定义id名称,open用于判断弹框是否打开。

(3)open方法

Modal.prototype.create = function() { if (!this.open) { var modal = document.createElement('div'); modal.innerHTML = this.html; modal.id = this.id; document.body.appendChild(modal); setTimeout(function() { modal.classList.add('show'); }, 0); this.open = true; } };复制代码

咱们在Modal的原型链上定义了create方法,方法内部咱们建立并向DOM中插入弹框,同时给弹框加上一个class为"show"的动画效果。这里简单介绍下classList:

classList是一个比className更便捷的操做元素class的属性,不过在兼容性方面不兼容IE10如下版本:

classList兼容性

其提供的操做class方法和jQuery的相似,主要有

  • add(class1, class2, ...) 在元素中添加一个或多个类名,相似jQuery的addClass()
  • remove(class1, class2, ...) 移除元素中一个或多个类名,相似jQuery的removeClass()
  • contains(class) 判断指定的类名是否存在,相似jQuery的hasClass()

这里咱们用到了add方法给Modal添加show类。

(4)close方法

Modal.prototype.delete = function() { if (this.open) { var modal = $(this.id); modal.classList.add('hide'); setTimeout(function() { document.body.removeChild(modal); }, 200); this.open = false; } };复制代码

定义了open方法后咱们这里定义关闭弹框的方法,在其内部给弹框对象添加hide类动画效果,最后在页面上移除弹框对象。

(5)建立实例

var createIntance = (function() { var instance; return function() { return instance || (instance = new Modal('modal', '这是一个弹框')) } })();复制代码

这是实现单例模式的重要部分,咱们来分析下知识点:

  1. 使用闭包封装了instance私有变量并返回一个函数
  2. 利用 || 语法判断若是instance不存在则执行后者的实例化Modal方法,存在则直接返回instance,确保了只存在一个弹框实例

本实例的建立也能够理解为代理模式的一部分。

(6)按钮操做

var operate = {
    setModal: null,
    open: function() { this.setModal = createIntance(); this.setModal.create(); }, delete: function() { this.setModal ? this.setModal.delete() : ''; } };复制代码

这里咱们将按钮操做放在operate对象里,使得打开和关闭操做能够经过this获取实例setModal。

(7)绑定事件

$('open').onclick = function() { operate.open(); }; $('delete').onclick = function() { operate.delete(); };复制代码

最后咱们将打开和删除方法绑定到两个按钮上去,至此咱们用单例模式实现的弹框demo就实现了。

完整代码请查看:完整代码

结语

本文只演示了单例模式的一种实现方式,至于如何构建一个通用的单例模式就交给有兴趣的读者了。

文章灵感来源于《Javascrit设计模式与开发实践》一书。

相关文章
相关标签/搜索