单例模式:保证一个类仅有一个实例,并提供一个访问它的全局访问点。

一、实现一个标准的单例模式,用一个变量来标志当前是否已经为某个类创建过对象, 如果是,则在下一次获取该对象实例时,直接返回之前创建的对象

  示例:

 var Singleton = function(name){
this.name = name;
this.instance = null; // 使用一个变量来表示是否已经创建该对象
}; Singleton.prototype.getName = function(){
console.log(this.name);
}; Singleton.getInstance = function(name){
if (!this.instance){
this.instance = new Singleton(name);
}
return this.instance;
}; var a = Singleton.getInstance("sven1");
var b = Singleton.getInstance("sven2"); console.log(a === b); // true
console.log(a.getName() + b.getName()); // sven1 sven1

  或者另一种写法:

 var Singleton= function(name){
this.name = name;
};
Singleton.prototype.getName = function(){
console.log(this.name);
}; Singleton.getInstance = (function(){
var instance = null; // 是否已创建对象的标志
return function(name){
if (!instance){
instance = new Singleton(name);
}
return instance;
};
})(); var a = Singleton.getInstance("A");
var b = Singleton.getInstance("B"); console.log(a === b); // true
console.log(a.getName() + b.getName()); // A A

二、使用代理实现单利模式

  下面的例子中,将使用 CreateDiv 单例类,作用是负责在页面中创建唯一的 div 节点

 //创建 div
var CreateDiv = function(html){
this.html = html;
this.init();
};
CreateDiv.prototype.init = function(){
var div = document.createElement("div");
div.innerHTML = this.html;
document.body.appendChild(div);
}; //单例模式控制类 proxySingletonCreateDiv
var ProxySingletonCreateDiv = (function(){
var instance = null;
return function(html){
if (!instance){
instance = new CreateDiv(html);
}
return instance;
}
})(); var a = new ProxySingletonCreateDiv("sven1");
var b = new ProxySingletonCreateDiv("sven2");
console.log(a===b);

三、JavaScript 中的单例模式

  单利模式的核心是确保只有一个示例,并提供全局访问

  全局变量不是单例模式,但我们可以把全局变量当成单利模式来时使用;例如:

var g = {};

  全局变量容易造成命名空间污染,应尽量减少全局变量的使用。减少全局污染的方法:

  1. 使用命名空间

var namespace1 = {
a: function(){
console.log(1);
},
b: function(){
console.log(2);
}
};

  2. 使用闭包封装私有变量

var user = (function(){
var _name = "sven",
_age = 29;
return {
getUserInfo: function(){
return _name + "-" + _age;
}
}
})();

  私有变量被封装在闭包产生的作用域中,外界访问不到这两个变量,就可以避免对全局命令的污染

四、惰性单例
  是指在我们需要的时候才可以创建对象实例。惰性单例是单例模式的重点。
  示例: 这个例子中,我们把创建实例对象的职责和管理对象的职责分别放置在两个方法里,这两个方法可以独立变化而互不影响,当他们链接在一起时,就完成创建唯一实力对象的功能,看起来是一件挺奇妙的事。

 //管理单例的逻辑代码
var getSingle = function(fn){
var result;
return function(){
return result || (result = fn.apply(this, arguments))
}
}; // 构造函数
var createLoginLayer = function(){
var div = document.createElement("div");
div.innnerHTML = "我是登陆悬浮窗";
div.style.display = "none";
document.body.appendChild(div);
return div;
}; var createSingleLoginLayer = getSingle(createLoginLayer); // 创建实例的方法
document.getElementById("loginBtn").onclick = function(){
var loginLayer = createSingleLoginLayer();
loginLayer.style.display = "block";
};

JavaScript设计模式 - 单例模式的更多相关文章

  1. JavaScript设计模式-单例模式、模块模式(转载 学习中。。。。)

    (转载地址:http://technicolor.iteye.com/blog/1409656) 之前在<JavaScript小特性-面向对象>里面介绍过JavaScript面向对象的特性 ...

  2. 探索Javascript设计模式---单例模式

    最近打算系统的学习javascript设计模式,以便自己在开发中遇到问题可以按照设计模式提供的思路进行封装,这样可以提高开发效率并且可以预先规避很多未知的问题. 先从最基本的单例模式开始. 什么是单例 ...

  3. javascript设计模式——单例模式

    前面的话 单例模式是指保证一个类仅有一个实例,并提供一个访问它的全局访问点. 单例模式是一种常用的模式,有一些对象往往只需要一个,比如线程池.全局缓存.浏览器中的window对象等.在javaScri ...

  4. [读书笔记] JavaScript设计模式: 单例模式

    单例模式:保证一个类只有一个实例,并提供一个可以访问它的全局访问点. 一种简单.方便的写法就是用一个变量来标识当前类是否已经创建过对象,如果有,则返回已经创建好的对象,否则创建一个新对象,并将其返回. ...

  5. javascript 设计模式-----单例模式

    单例模式的意思是只需要实例化某个类一次,它的方法也比较简单,通过判断某个类是否已经被实例化了,再返回该值.可以通过各种方法来实现单例模式,下面我们采取以下这种实现方式: var single = (f ...

  6. javascript设计模式--单例模式(Singleton)

    <!DOCTYPE HTML> <html lang="en-US"> <head> <meta charset="UTF-8& ...

  7. JavaScript设计模式—单例模式

    单例模式介绍 系统中被唯一使用的,一个类只有一个实例 单例模式的思路是: 一个类能返回一个对象的引用(并且永远是同一个)和一个获得该实例的方法(静态方法,通常使用 getInstance 名称). 那 ...

  8. JavaScript设计模式与开发实践 - 单例模式

    引言 本文摘自<JavaScript设计模式与开发实践> 在传统开发工程师眼里,单例就是保证一个类只有一个实例,实现的方法一般是先判断实例存在与否,如果存在直接返回,如果不存在就创建了再返 ...

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

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

随机推荐

  1. 【uoj150】 NOIP2015—运输计划

    http://uoj.ac/problem/150 (题目链接) 题意 给出一棵树以及m个询问,可以将树上一条边的权值修改为0,求经过这样的修改之后最长的边最短是多少. Solution 老早就听说过 ...

  2. Bzoj2705 Longge的问题

    Time Limit: 3000MS   Memory Limit: 131072KB   64bit IO Format: %lld & %llu Description Longge的数学 ...

  3. js中日历的代码

    Html <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3 ...

  4. iOS 刚刚,几分钟前,几小时前,几天前,几月前,几年前

    - (NSString *)compareCurrentTime:(NSDate*) compareDate { NSTimeInterval timeInterval = [compareDate ...

  5. codejumper的跳转代码

    public void JumpToSource(vsCMPart location = vsCMPart.vsCMPartNavigate) { TextPoint startPoint = Ori ...

  6. centos7 nginx用systemctl方式管理的脚本

    vim /usr/lib/systemd/system/nginx.service [Unit] Description=nginx - high performance web server Doc ...

  7. WPF TreeView绑定字典集合

    <TreeView Name="Tree" HorizontalAlignment="Left" Height="269" Width ...

  8. 如何使用Unix/Linux grep命令——磨刀不误砍柴工系列

     http://man.linuxde.net/grep ---------------------------------------------------- 如何使用Unix/Linux gre ...

  9. JS设置cookie,删除cookie

    js设置cookie有很多种方法. 第一种:(这个是w3c官网的代码) <script> //设置cookie function setCookie(cname, cvalue, exda ...

  10. javaScript模块化规范ADM与CMD

    模块化:模块化是指在解决某一个复杂问题时,依照一种分类的思维把问题进行系统性的分解处理,可以想象一个巨大的系统代码,被整合优化分割成逻辑性很强的模块时,对于软件是一种何等意义的存在. 模块化系统所必须 ...