首先我们对单例模式先进行理论上的讲解,接下来,我们再通过具体的代码示例,来讲解,这个单例模式的使用场景和这种模式的优缺点

(这个系列的所有关于设计模式的都是面向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 设计模式 之 单例模式的更多相关文章

  1. JavaScript设计模式之单例模式【惰性单例】

    在提高开发水平,往中高级前端工程师中,利用设计模式是必不可少的一条道路.掌握设计模式的思想远远比硬套重要,因为设计模式是一种思想,不局限于开发语言.但实际上由于语言的特性不同,往往在实现的时候会有不少 ...

  2. 《JavaScript高级程序设计(第3版)》阅读总结记录第一章之JavaScript简介

    前言: 为什么会想到把<JavaScript 高级程序设计(第 3 版)>总结记录呢,之前写过一篇博客,研究的轮播效果,后来又去看了<JavaScript 高级程序设计(第3版)&g ...

  3. 第一章:Javascript语言核心

    本节是javascript语言的一个快速预览,也是本书的第一部分快速预览. 读此书之前,感谢淘宝技术团队对此javascript核心的翻译,感谢弗拉纳根写出此书.感谢你们无私的分享,仅以此笔记献给你们 ...

  4. JavaScript DOM编程艺术第一章:JavaScript简史

    本系列的博客是由本人在阅读<JavaScript DOM编程艺术>一书过程中做的总结.前面的偏理论部分都是书中原话,觉得有必要记录下来,方便自己翻阅,也希望能为读到本博客的人提供一些帮助, ...

  5. 第一章 引言--《设计模式-可复用面向对象软件的基础》Erich Gamma

    第一章 引言 本章主要是让我们大致明白设计模式是干嘛用的,模式分类,设计模式如何解决设计问题以及几种常见的面向对象设计中软件的复用方法. 1.什么是设计模式? 个人理解概括,设计模式是对一类问题的抽象 ...

  6. JavaScript设计模式_01_单例模式

    最近项目不太忙,难得有时间看看书,平时挺喜欢js这门语言.也看过很多高级教程,觉得自己还是比较热衷于js的设计模式.这一次重温一下<JavaScript设计模式与开发实践>,开篇为单例模式 ...

  7. 再起航,我的学习笔记之JavaScript设计模式10(单例模式)

    单例模式 单例模式(Singleton) : 又被称为单体模式,是只允许实例化一次的对象类.一个类有且仅有一个实例,并且自行实例化向整个系统提供. 命名空间 单例模式可能是JavaScript中我们最 ...

  8. 为什么我要放弃javaScript数据结构与算法(第一章)—— JavaScript简介

    数据结构与算法一直是我算比较薄弱的地方,希望通过阅读<javaScript数据结构与算法>可以有所改变,我相信接下来的记录不单单对于我自己有帮助,也可以帮助到一些这方面的小白,接下来让我们 ...

  9. [JavaScript设计模式]惰性单例模式

    惰性单例模式 之前介绍了JS中类的单例模式,这次我们讨论下单例模式的应用.在众多网站中,登录框的实现方式就是一个单例,点击一次就展示一次,所以我们可以在页面加载好的时候就创建一个登录框,点击页面上的登 ...

随机推荐

  1. Linux crontab定时器的使用

    crontab参数: -u:帮助其他用户建立或移除工作排程 -l:查阅crontab的工作内容 -r:移除所有的crontab的工作内容 -e:编辑crontab文件 每项工作有六个字段: * * * ...

  2. [python]python try异常处理机制

    #python的try语句有两种风格 #一:种是处理异常(try/except/else) #二:种是无论是否发生异常都将执行最后的代码(try/finally) try/except/else风格 ...

  3. Eclipse CDT: Shortcut to switch between .h and .cpp

    ctrl+ tab  is the default shortcut.You can change it in Window → Preferences → General → Keys: Toggl ...

  4. CORS详解

    介绍 由于同源策略的缘故,以往我们跨域请求,会使用诸如JSON-P(不安全)或者代理(设置代理和维护繁琐)的方式.而跨源资源共享(Cross-Origin Resource Sharing)是一个W3 ...

  5. redis 学习笔记(7)-cluster 客户端(jedis)代码示例

    上节学习了cluster的搭建及redis-cli终端下如何操作,但是更常用的场景是在程序代码里对cluster读写,这需要redis-client对cluster模式的支持,目前spring-dat ...

  6. tensorflow学习笔记二:入门基础

    TensorFlow用张量这种数据结构来表示所有的数据.用一阶张量来表示向量,如:v = [1.2, 2.3, 3.5] ,如二阶张量表示矩阵,如:m = [[1, 2, 3], [4, 5, 6], ...

  7. 类EF框架Chloe.ORM升级:只为更完美

    扯淡 Chloe.ORM:一款轻量.高效的.NET C#数据库访问框架(ORM).查询接口借鉴 Linq(但不支持 Linq).借助 lambda 表达式,可以完全用面向对象的方式就能轻松执行多表连接 ...

  8. xwalk_core_library-15.44.384 .13.aar 百度云分享

    xwalk_core_library-15.44.384.13.aar 这玩意下载很慢 特意放到百度,需要的可以通过百度下载 http://pan.baidu.com/s/1nt0Cmbn 下完后放到 ...

  9. asp.net mvc 绑定客户端post过来的复杂JSON数据

    客户端代码如下: <input type="button" id="btnTest" value="测试" /><br / ...

  10. 如何有效地解决ie7,IE8不支持document.getElmentsByClassName的问题

    1.复制此代码到你js代码的最前面即可   if(!document.getElementsByClassName){ document.getElementsByClassName = functi ...