Javascript单例模式的介绍和实例


Posted in Javascript onOctober 08, 2016

前言

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

本文将会介绍Javascript中的单例模式,在传统开发工程师眼里,单例就是保证一个类只有一个实例,实现的方法一般是先判断实例存在与否,如果存在直接返回,如果不存在就创建了再返回,这就确保了一个类只有一个实例对象。在JavaScript里,单例作为一个命名空间提供者,从全局命名空间里提供一个唯一的访问点来访问该对象。下面来看看详细介绍。

单例模式概念

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

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

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

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

单例模式实例

1.demo展示

Javascript单例模式的介绍和实例

2.代码展示

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

(1)获取DOM对象

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以下版本:

Javascript单例模式的介绍和实例
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就实现了。

总结

本文只演示了单例模式的一种实现方式,至于如何构建一个通用的单例模式就交给有兴趣的读者了。以上就是这篇文章的全部内容了,希望能对大家的学习或者工作能带来一定的帮助。

Javascript 相关文章推荐
在JavaScript中通过URL传递汉字的方法
Apr 09 Javascript
jquery插件制作 表单验证实现代码
Aug 17 Javascript
jQuery 选择器项目实例分析及实现代码
Dec 28 Javascript
js 弹出框只弹一次(二次修改之后的)
Nov 26 Javascript
纯javascript实现图片延时加载方法
Aug 21 Javascript
Javascript的表单验证-提交表单
Mar 18 Javascript
Angular4项目中添加i18n国际化插件ngx-translate的步骤详解
Jul 02 Javascript
jQuery事件_动力节点Java学院整理
Jul 05 jQuery
js判断节假日实例代码
Dec 27 Javascript
使用JavaScript保存文本文件到本地的两种方法
Jan 22 Javascript
javascript canvas检测小球碰撞
Apr 17 Javascript
微信小程序中使用 async/await的方法实例分析
May 06 Javascript
jquery把int类型转换成字符串类型的方法
Oct 07 #Javascript
jquery判断类型是不是number类型的实例代码
Oct 07 #Javascript
js判断是否为空和typeof的用法(详解)
Oct 07 #Javascript
浅谈js的ajax的异步和同步请求的问题
Oct 07 #Javascript
jquery删除table当前行的实例代码
Oct 07 #Javascript
JS控制FileUpload的上传文件类型实例代码
Oct 07 #Javascript
jQuery+正则+文本框只能输入数字的实现方法
Oct 07 #Javascript
You might like
总集篇&特番节目先行播出!《SAO Alicization War of Underworld》第2季度TV动画4月25日放送!
2020/03/06 日漫
批量修改RAR文件注释的php代码
2010/11/20 PHP
PHPUnit + Laravel单元测试常用技能
2019/11/06 PHP
laravel框架select2多选插件初始化默认选中项操作示例
2020/02/18 PHP
用JavaScript计算在UTF-8下存储字符串占用字节数
2013/08/08 Javascript
javascript实现验证IP地址等相关信息代码
2015/05/10 Javascript
浅谈jquery拼接字符串效率比较高的方法
2017/02/22 Javascript
js判断用户是输入的地址请求的路径(实例讲解)
2017/07/18 Javascript
H5+C3+JS实现五子棋游戏(AI篇)
2020/05/28 Javascript
vue.js实现图书管理功能
2019/09/24 Javascript
vue实现短信验证码输入框
2020/04/17 Javascript
node.js爬虫框架node-crawler初体验
2020/10/29 Javascript
[02:18]DOTA2英雄基础教程 育母蜘蛛
2014/01/20 DOTA
新手该如何学python怎么学好python?
2008/10/07 Python
Python统计列表中的重复项出现的次数的方法
2014/08/18 Python
python读取json文件并将数据插入到mongodb的方法
2015/03/23 Python
用ReactJS和Python的Flask框架编写留言板的代码示例
2015/12/19 Python
使用Python的PIL模块来进行图片对比
2016/02/18 Python
Python设计模式之工厂模式简单示例
2018/01/09 Python
Python基于TCP实现会聊天的小机器人功能示例
2018/04/09 Python
Python(TensorFlow框架)实现手写数字识别系统的方法
2018/05/29 Python
python高级特性和高阶函数及使用详解
2018/10/17 Python
Python实现蒙特卡洛算法小实验过程详解
2019/07/12 Python
python 判断三个数字中的最大值实例代码
2019/07/24 Python
Python 依赖库太多了该如何管理
2019/11/08 Python
pytorch forward两个参数实例
2020/01/17 Python
Python爬虫设置ip代理过程解析
2020/07/20 Python
python在linux环境下安装skimage的示例代码
2020/10/14 Python
viagogo英国票务平台:演唱会、体育比赛、戏剧门票
2017/03/24 全球购物
C语言中一个结构不能包含指向自己的指针吗
2012/05/25 面试题
远程调用的原理
2014/07/05 面试题
国贸专业个人求职信范文
2014/01/08 职场文书
军校本科大学生自我评价
2014/01/14 职场文书
公证书标准格式
2014/04/10 职场文书
婚宴祝酒词大全
2015/08/10 职场文书
2016年大学生就业指导课心得体会
2015/10/09 职场文书