摘要:本文将介绍模式中较为常见和实用的模式单例模式,主要分为概念和实例部分。单例模式概念首先什么是单例模式可以这样理解单例模式旨在保证一个类仅有一个实例,并提供一个全局的访问点。文章灵感来源于设计模式与开发实践一书。
前言
和其他编程语言一样,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设计模式与开发实践》一书。
本文首发于微信公众号:前端呼啦圈(Love-FED)
博客园:http://www.cnblogs.com/luozhi...
segmentfault:https://segmentfault.com/a/11...
简书:http://www.jianshu.com/p/52bb...
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/80575.html
摘要:现在让我们设置温度值并将其增加减少几次小结在中,单例模式根据是否懒汉模式饿汉模式以及是否线程安全,分为很多种实现方式。参考设计模式与开发实践设计模式 Back in 1994, a book was authored by Erich Gamma, Richard Helm, Ralph Johnson and John Vlissides that discusses 23 desg...
摘要:注意事项声明函数时候处理业务逻辑区分和单例的区别,配合单例实现初始化构造函数大写字母开头推荐注意的成本。简单工厂模式使用一个类通常为单体来生成实例。 @(书籍阅读)[JavaScript, 设计模式] 常见设计模式 一直对设计模式不太懂,花了一下午加一晚上的时间,好好的看了看各种设计模式,并总结了一下。 设计模式简介 设计模式概念解读 设计模式的发展与在JavaScript中的应用 ...
摘要:引言本文摘自设计模式与开发实践在传统开发工程师眼里,单例就是保证一个类只有一个实例,实现的方法一般是先判断实例存在与否,如果存在直接返回,如果不存在就创建了再返回,这就确保了一个类只有一个实例对象。 引言 本文摘自《JavaScript设计模式与开发实践》 在传统开发工程师眼里,单例就是保证一个类只有一个实例,实现的方法一般是先判断实例存在与否,如果存在直接返回,如果不存在就创建了再返...
摘要:但是,这并不是采用单例的唯一原因。使用命名空间单例模式也被称为模块设计模式。函数内部声明了一些局部函数和或变量。紧随函数声明放置即可立即执行外部函数,并将所得的对象文字费赔给变量。 JavaScript设计模式-第一部分:单例模式、组合模式和外观模式 设计模式是一些可靠的编程方式,有助于保证代码更加易于维护、扩展及分离,所有设计模式在创建大型JavaScript应用程序时均不可或缺 单...
摘要:什么时候需要用到单例模式呢其实单例模式在日常开发中的使用非常的广泛,例如各种浮窗像登录浮窗等,无论我们点击多少次,都是同一个浮窗,浮窗从始至终只创建了一次。这种场景就十分适合运用单例模式。 单例模式 什么是单例模式? 单例模式的定义:一个类仅有一个实例,并且可以在全局访问。什么时候需要用到单例模式呢?其实单例模式在日常开发中的使用非常的广泛,例如各种浮窗、像登录浮窗等,无论我们点击多少...
阅读 3282·2023-04-26 02:09
阅读 2578·2021-11-24 09:39
阅读 3269·2021-11-16 11:52
阅读 3617·2021-10-26 09:50
阅读 2774·2021-10-08 10:05
阅读 2458·2021-09-22 15:25
阅读 3301·2019-08-30 13:14
阅读 910·2019-08-29 17:06