标签:function return name instance 单例 var 设计模式 金服
-
传统的单例模式和new 创建对象的调用不一样
-
调用者要调用xxx.getInstance才能获得该单例
function Singleton(name) {
this.name = name;
}
Singleton.getInstance = function (name) {
if(this.instace){
return this.instace;
}else {
this.instace = new Singleton(name);
return this.instace;
}
};
var a = Singleton.getInstance('a');
var b = Singleton.getInstance('b');
console.log(a===b); //true
5."透明"的单例模式
-
透明”的单例类,用户从这个类中创建对象的时候,可以像使用其他任何普通类一样
-
直接 new 一个对象
-
不能new 多个对象,扩展性不好
var instace;
function Person(name) {
this.name = name;
if (!instace) {
instace = this;
}
return instace;
}
Person.prototype.getName = function () {
console.log(this.name);
};
var a = new Person('a');
var b = new Person('b');
console.log(a===b);
6.代理模式创建单例模式
-
代理模式:自己不去做,委托中间人做
-
Person是一个普通类,通过new Person可以创建一个对象
-
用代理模式创建CreateSinglePerson方法,通过new CreateSinglePerson可以创建一个单例
function Person(name) {
this.name = name;
}
Person.prototype.getName = function () {
console.log(this.name);
};
var CreateSinglePerson = (function (name) {
var instance;
return function () {
if (!instance) {
instance = new Person(name);
}
return instance;
};
})();
var a = new CreateSinglePerson('a');
var b = new CreateSinglePerson('b');
console.log(a === b);
var c = new Person('c');
var d = new Person('d');
console.log(c === d);
JavaScript中的单例模式
-
单例模式的核心是确保只有一个实例,并提供全局访问
-
在JavaScript可以通过直接创建一个对象来实现单例模式
-
可以用闭包的方式实现私有变量
let MyApp = {
name:'app',
getName:function() {
console.log(this.name);
}
};
let MyApp2 = (function(){
var _name = 'app';
return {
getName:function() {
console.log(_name);
}
}
})();
#####惰性单例
-
惰性单例是指在需要的时候才创建
-
标签:function,return,name,instance,单例,var,设计模式,金服 来源: https://blog.csdn.net/m0_61418427/article/details/120147693
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。