Javascript实现单例模式
作者:bea
单例模式也称作为单子模式,更多的也叫做单体模式。为软件设计中较为简单但是最为常用的一种设计模式。 单例模式的介绍: 在应用单例模式时,生成单例的类必须保证只有一个实例的存在,很多时候整个系统只需要拥有一个全局对象,才有利于协调系统整体的行为。比如在整个系统的配置文件中,配置数据有一个单例对象进行统一读取和修改,其他对象需要配置数据的时候也统一通过该单例对象来获取配置数据,这样就可以简化复杂环境下的配置管理。 单例模式的思路是:一个类能返回一个对象的引用(并且永远是同一个)
单例模式也称作为单子模式,更多的也叫做单体模式。为软件设计中较为简单但是最为常用的一种设计模式。
单例模式的介绍:
在应用单例模式时,生成单例的类必须保证只有一个实例的存在,很多时候整个系统只需要拥有一个全局对象,才有利于协调系统整体的行为。比如在整个系统的配置文件中,配置数据有一个单例对象进行统一读取和修改,其他对象需要配置数据的时候也统一通过该单例对象来获取配置数据,这样就可以简化复杂环境下的配置管理。
单例模式的思路是:一个类能返回一个对象的引用(并且永远是同一个)和一个获得该实例的方法(静态方法,通常使用 getInstance 名称)。那么当我们调用这个方法时,如果类持有的引用不为空就返回该引用,否者就创建该类的实例,并且将实例引用赋值给该类保持的那个引用再返回。同时将该类的构造函数定义为私有方法,避免其他函数使用该构造函数来实例化对象,只通过该类的静态方法来得到该类的唯一实例。
一般情况下,Javascript每次new一个对象就产生一个实例,实例指向不同的地址。就像如下:
(function(){
function Person(name){
this.name = name;
}
Person.prototype.work = function(){
console.log(this.name + " is working");
}
var p1 = new Person("Darren");
p1.work();
var p2 = new Person("Jack");
p2.work();
}());
以上,每次new出一个Person对象都是不同的。
如何在Javascript中实现单例模式呢?
--在生成某各对象时先判断是否存在。存在就不生成对象,不存在就生成对象。
(function(){
var PersonSingleton = (function(){
var instance;
function init(){
return {
name: 'Anonymous',
work: function(){
console.log(this.name + ' working');
}
};
}
return {
getInstance: function(){
if(!instantiated){
instantiated = init();
}
return instantiated;
}
}
})();
var p1 = PersonSingleton.getInstance();
p1.work();
var p2 = PersonSingleton.getInstance();
p2.work();
}());
以上,通过PsonSIngleton对象的getInstance方法得到的实例每次都是一样的。
关于javascript单例模式的相关知识就给大介绍到这里,希望对大家有所帮助。
有用 | 无用
单例模式的介绍:
在应用单例模式时,生成单例的类必须保证只有一个实例的存在,很多时候整个系统只需要拥有一个全局对象,才有利于协调系统整体的行为。比如在整个系统的配置文件中,配置数据有一个单例对象进行统一读取和修改,其他对象需要配置数据的时候也统一通过该单例对象来获取配置数据,这样就可以简化复杂环境下的配置管理。
单例模式的思路是:一个类能返回一个对象的引用(并且永远是同一个)和一个获得该实例的方法(静态方法,通常使用 getInstance 名称)。那么当我们调用这个方法时,如果类持有的引用不为空就返回该引用,否者就创建该类的实例,并且将实例引用赋值给该类保持的那个引用再返回。同时将该类的构造函数定义为私有方法,避免其他函数使用该构造函数来实例化对象,只通过该类的静态方法来得到该类的唯一实例。
一般情况下,Javascript每次new一个对象就产生一个实例,实例指向不同的地址。就像如下:
(function(){
function Person(name){
this.name = name;
}
Person.prototype.work = function(){
console.log(this.name + " is working");
}
var p1 = new Person("Darren");
p1.work();
var p2 = new Person("Jack");
p2.work();
}());
以上,每次new出一个Person对象都是不同的。
如何在Javascript中实现单例模式呢?
--在生成某各对象时先判断是否存在。存在就不生成对象,不存在就生成对象。
(function(){
var PersonSingleton = (function(){
var instance;
function init(){
return {
name: 'Anonymous',
work: function(){
console.log(this.name + ' working');
}
};
}
return {
getInstance: function(){
if(!instantiated){
instantiated = init();
}
return instantiated;
}
}
})();
var p1 = PersonSingleton.getInstance();
p1.work();
var p2 = PersonSingleton.getInstance();
p2.work();
}());
以上,通过PsonSIngleton对象的getInstance方法得到的实例每次都是一样的。
关于javascript单例模式的相关知识就给大介绍到这里,希望对大家有所帮助。
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- 在AngularJS中如何使用谷歌地图把当前位置显示出来
- 理解JavaScript表单的基础知识
- jquery获取文档高度和窗口高度汇总
- JavaScript数组的一些奇葩行为
- JavaScript文本框脚本编写的注意事项
- 详解js私有作用域中创建特权方法
- 超赞的jQuery图片滑块动画特效代码汇总
- 理解js对象继承的N种模式
- 解决js函数闭包内存泄露问题的办法
- JavaScript数据类型学习笔记
- 分步解析JavaScript实现tab选项卡自动切换功能
- jQuery form 表单验证插件(fieldValue)校验表单
- Jquery实现纵向横向菜单
- JavaScript、jQuery与Ajax的关系
- JavaScript jquery及AJAX小结
- 基于JavaScript短信验证码如何实现
- 详解JS面向对象编程
- js中实现字符串和数组的相互转化详解
- JavaScript基础知识之方法汇总结