前言
其实和其他编程语言一样,Javascript同样拥有着很多种设计模式,比如单例模式、代理模式、观察者模式等,熟练运用Javascript的设计模式可以使我们的代码逻辑更加清晰,并且更加易于维护和重构。
本文将会介绍Javascript中的单例模式,在传统开发工程师眼里,单例就是保证一个类只有一个实例,实现的方法一般是先判断实例存在与否,如果存在直接返回,如果不存在就创建了再返回,这就确保了一个类只有一个实例对象。在JavaScript里,单例作为一个命名空间提供者,从全局命名空间里提供一个唯一的访问点来访问该对象。下面来看看详细介绍。
单例模式概念
首先什么是单例模式?可以这样理解:单例模式旨在保证一个类仅有一个实例,并提供一个全局的访问点。
可能有人还是不太理解单例的概念,那么你可以想象生活中的一些例子。比如注册账号的时候,如果我们注册的账号已经存在,那么系统会提示我们“账号已经存在是否使用该账号登陆”,我们无法再次创建一个一模一样的账号,除非把原账号注销。这就是单例模式的生动体现。
类似的例子还有网页上的登陆弹框,无论我们点击多少次登陆按钮,界面上始终只会显示一个登陆弹框,无法再创建第二个。
本文就将以登陆弹框为例介绍单例模式的使用方式。
单例模式实例
1.demo展示
2.代码展示
构建单例模式弹框实例的代码每个人可能写的都不一样,但是目的都是一个:构建一个全局唯一并可访问的弹框。接下来我们一步一步来实现这个例子。
(1)获取DOM对象
var $ = function(id) { return typeof id === 'string' "htmlcode">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', '这是一个弹框')) } })();这是实现单例模式的重要部分,我们来分析下知识点:
1、使用闭包封装了
instance
私有变量并返回一个函数
2、利用 || 语法判断如果
instance
不存在则执行后者的实例化Modal
方法,存在则直接返回instance
,确保了只存在一个弹框实例
本实例的创建也可以理解为代理模式的一部分。
(6)按钮操作
var operate = { setModal: null, open: function() { this.setModal = createIntance(); this.setModal.create(); }, delete: function() { this.setModal "htmlcode">$('open').onclick = function() { operate.open(); }; $('delete').onclick = function() { operate.delete(); };最后我们将打开和删除方法绑定到两个按钮上去,至此我们用单例模式实现的弹框demo就实现了。
总结
本文只演示了单例模式的一种实现方式,至于如何构建一个通用的单例模式就交给有兴趣的读者了。以上就是这篇文章的全部内容了,希望能对大家的学习或者工作能带来一定的帮助。
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?