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

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

  示例:

 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. ci中如何得到配置的url

    $this->load->helper('url'); 然后,你可以用它查询并返回设置在config.php文件中的site和/或base URL: echo site_url(); ec ...

  2. Idea 添加lib文件夹,并添加至项目Libary

    在WEB-INF文件夹下新建lib文件夹,在lib文件夹上右键选择Add as Libary...,然后填写library名称,选择作用级别,选择作用项目,OK 注意:lib文件夹下需要有jar包后才 ...

  3. Ten Tips for Writing CS Papers, Part 2

    Ten Tips for Writing CS Papers, Part 2 This continues the first part on tips to write computer scien ...

  4. awk命令--update20150120

    简介 awk是一个强大的文本分析工具,把文件逐行读入,以空格为默认分隔符分割成field,切开的部分再进行各种分析处理. 模式和动作: 任何awk语句都是由模式和动作组成,模式部分决定动作语句何时触发 ...

  5. 面试题52:缺少i的乘积数组

    vector<int> multiply(const vector<int>& A) { int len = A.size(); vector<); result ...

  6. 网站性能Web压力测试工具webbench

    webbench最多可以模拟3万个并发连接去测试网站的负载能力,个人感觉要比Apache自带的ab压力测试工具好,安装使用也特别方便. 1.适用系统:Linux 2.编译安装: wget http:/ ...

  7. 改变placeholder颜色

    /* WebKit browsers */ ::-webkit-input-placeholder { color: red; text-overflow: ellipsis; } /* Mozill ...

  8. MySQL导出数据库

    MySQL命令行导出数据库: 1,进入MySQL目录下的bin文件夹:cd MySQL中到bin文件夹的目录 如我输入的命令行:cd D:\Program\MySQL\MySQL Server 5.0 ...

  9. java 打包过程及如何使用第三方jar包

    地址:http://wenku.baidu.com/view/44a1bbed81c758f5f61f6779.html或者 http://wenku.it168.com/d_000575231.sh ...

  10. Quartz.net开源作业调度框架使用详解(转)

    前言 quartz.net作业调度框架是伟大组织OpenSymphony开发的quartz scheduler项目的.net延伸移植版本.支持 cron-like表达式,集群,数据库.功能性能强大更不 ...