Javascript单例模式概念与实例
前言
和其他编程语言一样,Javascript同样拥有着很多种设计模式,比如单例模式、代理模式、观察者模式等,熟练运用Javascript的设计模式可以使我们的代码逻辑更加清晰,并且更加易于维护和重构。
本文将介绍Javascript模式中较为常见和实用的模式——单例模式,主要分为概念和实例部分。在介绍实例的同时也会对代码中额外的知识点进行讲解。
单例模式概念
首先什么是单例模式?可以这样理解:单例模式旨在保证一个类仅有一个实例,并提供一个全局的访问点。
可能有人还是不太理解单例的概念,那么你可以想象生活中的一些例子。比如注册账号的时候,如果我们注册的账号已经存在,那么系统会提示我们“账号已经存在是否使用该账号登陆”,我们无法再次创建一个一模一样的账号,除非把原账号注销。这就是单例模式的生动体现。
类似的例子还有网页上的登陆弹框,无论我们点击多少次登陆按钮,界面上始终只会显示一个登陆弹框,无法再创建第二个。
本文就将以登陆弹框为例介绍单例模式的使用方式。
单例模式实例
1.demo展示
演示地址为:弹框实例
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以下版本:
其提供的操作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', '这是一个弹框'))
}
})();
这是实现单例模式的重要部分,我们来分析下知识点:
- 使用闭包封装了instance私有变量并返回一个函数
- 利用 || 语法判断如果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设计模式与开发实践》一书。
最新文章
- elasticsearch高级配置一 ---- 分片分布规则设置
- MYSQL的卸载
- 64-who 简明笔记
- Only one statement is allowed per batch. A batch separator, such as 'GO', might be required between statements.
- 运行js提示库没有注册错误8002801d的解决办法
- hdu5832 A water problem
- HTML5 Web SQL Database 数据库的使用方法【图文说明】
- WPF换肤之六:酷炫的时区浏览小精灵
- cygwin的163镜像(转)
- 关于C++中的前置声明(附程序运行图)
- 如何自定义Django数据库中的字段
- 题解-bzoj4061 CERC-2012Farm and Factory
- Linux 之 rsyslog 系统日志转发
- [No0000142]Outlook通过添加签名 自动添加邮件模板
- kafka消息队列的简单理解
- Grid布局20行代码快速生成瀑布流
- # pc端个性化日历实现
- 170705、springboot编程之自定义properties
- HDU 6201 transaction transaction transaction(树形DP)
- POJ-2594
热门文章
- 无法向会话状态服务器发出会话状态请求。请确保 ASP.NET State Service (ASP.NET 状态服务)已启动,并且客户端端口与服务器端口相同。如果服务器位于远程计算机上,请检查。。。
- 不懂CSS的后端难道就不是好程序猿?
- 脑洞大开之采用HTML5+SignalR2.0(.Net)实现原生Web视频
- Flyweight(享元模式)
- iOS在导航栏上居中显示分段控件(UISegmentedControl)
- linux下配置matlab运行环境(MCR)
- Harmonic Number(调和级数+欧拉常数)
- ASP.NET 5运行时升级到Beta5
- Dubbo学习小记
- CS Coder学习asp.net5个月的最大感悟:从http的角度重新认识asp.net(二)——我理解的ajax(二)