Javascript单例模式概念与实例

前言

10年积累的做网站、成都网站设计经验,可以快速应对客户对网站的新想法和需求。提供各种问题对应的解决方案。让选择我们的客户得到更好、更有力的网络服务。我虽然不认识你,你也不认识我。但先网站设计后付款的网站建设流程,更有宛城免费网站建设让你可以放心的选择与我们合作。

和其他编程语言一样,Javascript同样拥有着很多种设计模式,比如单例模式、代理模式、观察者模式等,熟练运用Javascript的设计模式可以使我们的代码逻辑更加清晰,并且更加易于维护和重构。

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

单例模式概念

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

可能有人还是不太理解单例的概念,那么你可以想象生活中的一些例子。比如注册账号的时候,如果我们注册的账号已经存在,那么系统会提示我们“账号已经存在是否使用该账号登陆”,我们无法再次创建一个一模一样的账号,除非把原账号注销。这就是单例模式的生动体现。

类似的例子还有网页上的登陆弹框,无论我们点击多少次登陆按钮,界面上始终只会显示一个登陆弹框,无法再创建第二个。

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

单例模式实例

1.demo展示

 演示地址为:弹框实例

2.代码展示

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

(1)获取DOM对象

 
 
  1. var $ = function(id) {
  2. return typeof id === 'string' ? document.getElementById(id) : id;
  3. }; 

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

(2)弹框构造函数

 
 
  1. var Modal = function(id, html) {
  2. this.html = html;
  3. this.id = id;
  4. this.open = false;
  5. }; 

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

(3)open方法

 
 
  1. Modal.prototype.create = function() {
  2.     if (!this.open) {
  3.         var modal = document.createElement('div');
  4.     
  5.         modal.innerHTML = this.html;
  6.         modal.id = this.id;
  7.         document.body.appendChild(modal);
  8.     
  9.         setTimeout(function() {
  10.             modal.classList.add('show');
  11.         }, 0);
  12.         
  13.         this.open = true;
  14.     }
  15. }; 

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

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

 其提供的操作class方法和jQuery的类似,主要有

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

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

(4)close方法

 
 
  1. Modal.prototype.delete = function() {
  2.     if (this.open) {
  3.         var modal = $(this.id);
  4.     
  5.         modal.classList.add('hide'); 
  6.         setTimeout(function() {
  7.             document.body.removeChild(modal);
  8.         }, 200);
  9.         
  10.         this.open = false;
  11.     }
  12. }; 

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

(5)创建实例

 
 
  1. var createIntance = (function() {
  2.     var instance;
  3.     return function() {
  4.         return instance || (instance = new Modal('modal', '这是一个弹框'))
  5.     }
  6. })(); 

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

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

本实例的创建也可以理解为代理模式的一部分。

(6)按钮操作

 
 
  1. var operate = {
  2.     setModal: null,
  3.     open: function() {
  4.         this.setModal = createIntance();
  5.         this.setModal.create();
  6.     },
  7.     delete: function() {
  8.         this.setModal ? this.setModal.delete() : '';
  9.     }
  10. };

 这里我们将按钮操作放在operate对象里,使得打开和关闭操作可以通过this获取实例setModal。

(7)绑定事件

 
 
  1. $('open').onclick = function() {
  2.     operate.open();
  3. };
  4. $('delete').onclick = function() {
  5.     operate.delete();
  6. }; 

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

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

结语

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

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

分享文章:Javascript单例模式概念与实例
本文来源:http://www.csdahua.cn/qtweb/news17/72917.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网