第一章 --- 关于Javascript 设计模式 之 单例模式
首先我们对单例模式先进行理论上的讲解,接下来,我们再通过具体的代码示例,来讲解,这个单例模式的使用场景和这种模式的优缺点
(这个系列的所有关于设计模式的都是面向Javascript)
一、理论定义:
单例模式 --- 保证一个类仅有一个实例,并提供一个访问它的全局访问点 (是不是有点懵逼了,其实我第一次看到这句话的时候也是懵逼的,继续往下看呗)
二、话不多说直接上一个最简单的单例模式的代码:
var SingleDog = function(name){ //创建构造函数
this.name = name;
this.instance = null;
}
SingleDog.prototype.getName = function(){ //SingleDog对象获取当前name方法
return this.name;
}
SingleDog.getInstance = function(name){ //获取实例化方法
if(!this.instance){
this.instance = new SingleDog(name);
}
return this.instance;
}
var a = SingleDog.getInstance('Zigzag'); //实例化 并将结果对象 赋值给a
var b = SingleDog.getInstance('Bing'); //实例化 并将结果对象 赋值给b
console.log(a.getName()); //这个大家一看很明显就知道了(Zigzag)
console.log(b.getName()); //这个 呢?
console.log(a === b); // true
今天先写这么多吧,明天回来继续
回来继续~
二、上面的代码,通过长时间的阅读和理解。其实就是在 实例化的过程中,我们去改变一个我们事先定义好的变量值,从而达到控制且只有一个单例的目的。
接下来,我们再看一段,我们开发过程中应用的更多的有一些实际作用的代码。
/*
*功能: 实现点击显示或者创建一个 浮层(div)
*对比: 这里会写 两种方法 来实现这个需求
*/
1、第一种就是我们 常常使用的 display 的方法。
<button id="login">登陆</button>
var loginlayer = (function(){
var div = document.createElement('div');
div.innerHTML = "我的登陆浮层";
div.style.display = 'none';
document.body.appendChild(div);
return div;
})();
document.getElementById('login').onclick = function(){
loginlayer.style.display = 'block';
}
虽然这种方法我们常常用,而且也实现了我们想要的需求,但是,在页面一被加载的时候就 创建了一些 DOM 这样是不可取的。 因为浪费。(太洁癖了吧)
2、第二种方法来实现这个需求, 我们一步步来优化这段代码。
var loginlayer = function(){
var div = document.createElement('div');
div.innerHTML = "我的登陆浮层";
div.style.display = 'none';
document.body.appendChild(div);
return div;
};
document.getElementById('login').onclick = function(){
var loginlayers = loginlayer();
loginlayer.style.display = 'block';
}
//这样的话,我们是不是只有在用户去点击 btn 的时候,我们才会去创建我们的DOM 。
// 虽然需求是 实现了,但是并木有用到我们的 单例模式。并且如果我们点击关闭并删除这个layer 的话,这样频繁的创建和删除节点明显也是不合理的。
//(但是这里切记,我们只是为了学习单例模式才去,进行下一步的 优化,学习设计模式是为了学习这些模式的思想,而不是为了去 生搬硬套这些代码。)
3、第三种方法来实现这个需求,使用我们的 单例模式来实现这个需求,大家可以先别看下面的代码, 先想一想怎么去构建自己的代码来实现单例模式。
var Createloginlayer = function(){
var div;
return function(){
if(!div){
var div = document.createElement('div');
div.innerHTML = "我的登陆浮层";
div.style.display = 'none';
document.body.appendChild(div);
}
return div;
}
};
document.getElementById('login').onclick = function(){
var loginlayers = Createloginlayer();
loginlayer.style.display = 'block';
}
看完第三种 实现这个需求的代码之后会不会觉的 很高大上,而且也很合理。
这里我们就是应用了单例模式的 一个 特性,即: 我们用了一个变量来判断时候已经创建了我们的节点,这样在重复这些操作的时候,我们可以仅仅只创建一次节点。
这里就是我们 常常会用到的 ##惰性单利模式。
今天就到这里了,明天继续~ 明天会写一些 通用的 惰性单例.
第一章 --- 关于Javascript 设计模式 之 单例模式的更多相关文章
- JavaScript设计模式之单例模式【惰性单例】
在提高开发水平,往中高级前端工程师中,利用设计模式是必不可少的一条道路.掌握设计模式的思想远远比硬套重要,因为设计模式是一种思想,不局限于开发语言.但实际上由于语言的特性不同,往往在实现的时候会有不少 ...
- 《JavaScript高级程序设计(第3版)》阅读总结记录第一章之JavaScript简介
前言: 为什么会想到把<JavaScript 高级程序设计(第 3 版)>总结记录呢,之前写过一篇博客,研究的轮播效果,后来又去看了<JavaScript 高级程序设计(第3版)&g ...
- 第一章:Javascript语言核心
本节是javascript语言的一个快速预览,也是本书的第一部分快速预览. 读此书之前,感谢淘宝技术团队对此javascript核心的翻译,感谢弗拉纳根写出此书.感谢你们无私的分享,仅以此笔记献给你们 ...
- JavaScript DOM编程艺术第一章:JavaScript简史
本系列的博客是由本人在阅读<JavaScript DOM编程艺术>一书过程中做的总结.前面的偏理论部分都是书中原话,觉得有必要记录下来,方便自己翻阅,也希望能为读到本博客的人提供一些帮助, ...
- 第一章 引言--《设计模式-可复用面向对象软件的基础》Erich Gamma
第一章 引言 本章主要是让我们大致明白设计模式是干嘛用的,模式分类,设计模式如何解决设计问题以及几种常见的面向对象设计中软件的复用方法. 1.什么是设计模式? 个人理解概括,设计模式是对一类问题的抽象 ...
- JavaScript设计模式_01_单例模式
最近项目不太忙,难得有时间看看书,平时挺喜欢js这门语言.也看过很多高级教程,觉得自己还是比较热衷于js的设计模式.这一次重温一下<JavaScript设计模式与开发实践>,开篇为单例模式 ...
- 再起航,我的学习笔记之JavaScript设计模式10(单例模式)
单例模式 单例模式(Singleton) : 又被称为单体模式,是只允许实例化一次的对象类.一个类有且仅有一个实例,并且自行实例化向整个系统提供. 命名空间 单例模式可能是JavaScript中我们最 ...
- 为什么我要放弃javaScript数据结构与算法(第一章)—— JavaScript简介
数据结构与算法一直是我算比较薄弱的地方,希望通过阅读<javaScript数据结构与算法>可以有所改变,我相信接下来的记录不单单对于我自己有帮助,也可以帮助到一些这方面的小白,接下来让我们 ...
- [JavaScript设计模式]惰性单例模式
惰性单例模式 之前介绍了JS中类的单例模式,这次我们讨论下单例模式的应用.在众多网站中,登录框的实现方式就是一个单例,点击一次就展示一次,所以我们可以在页面加载好的时候就创建一个登录框,点击页面上的登 ...
随机推荐
- jQuery 获取 radio 选中后的文字
如果html为 <input type="radio" id="test" name="test" value="1&quo ...
- IIS中启用ASP并连接Access数据库的解决办法
1. IIS安装ASP模块 进入控制面板 ---- 打开或关闭Windows功能 选择如下所示两项,点击安装完成 2. 打开父路径许可 选择相应应用程序池 ----- 高级设置 ---- 将“启用父路 ...
- mongodb简介(转)
1.简介 MongoDB是一个基于分布式文件存储的数据库.由C++语言编写.旨在为WEB应用提供可扩展的高性能数据存储解决方案. MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数 ...
- IISExpress Log 文件路径
问题 用VS做开发时经常用IISExpress测试web程序,那么在测试过程中生成的Log文件放在哪里了? 答案 情况1 默认情况下 applicationhost.config 文中定义了连个日志文 ...
- 自定义asp.net 脚手架(基架)
Tutorials To create a customized scaffolder, see Creating a Custom Scaffolder for Visual Studio. To ...
- 【原】为什么选择iPhone5的分辨率作为H5视觉稿尺寸
[20160105更新:可以用iPhone6分辨率为视觉稿尺寸啦] 又是一年的520网络情人节,深圳这边却下了大雨,这雨只能是单身汉的泪,而对于我来说这一天具有特别的意义,一来怀念父亲,二来对我这种结 ...
- PHP代码
1 <html> <head> <meta http-equiv="content-type" content="text/h ...
- Qt 开启鼠标跟踪,自动激活mouseMoveEvent的问题
最近在Qt上实现一个功能,鼠标在图片上移动,触发mouseMoveEvent事件,进而生成一个小的半透明窗口,放大显示以鼠标为中心的一个区域的图像并随鼠标移动.但是,必须鼠标摁下,才触发mouseMo ...
- redis慢查询日志
运维需要记录一下主redis中那些“慢操作”的命令,然后找到相关的业务方,不然的话,阻塞 就不好玩了.然后就直接在redis手册中就找到了相关的命令. SLOWLOG subcommand [argu ...
- eclipse直接访问数据库
本文转载至百度经验 http://jingyan.baidu.com/article/a501d80cea3ed4ec630f5e2f.html 以oracle 11g 数据库为例