單例模式
定義
保證一個(gè)類只有一個(gè)實(shí)例碎税,并提供一個(gè)訪問他的全局訪問點(diǎn)
實(shí)現(xiàn)單例模式
function Single (name) {
this.name = name;
}
Single.prototype.getName = function () {
console.log(this.name);
}
Single.getSingle = (function () {
var instance = null;
return function (name) {
if (!instance) {
instance = new Single(name);
}
return instance;
}
})()
var instance1 = Single.getSingle('instance1');
var instance2 = Single.getSingle('instance2');
instance1.getName(); // instance1
instance2.getName(); // instance2
全局變量不是單例模式
var a = {}
當(dāng)用這種方式創(chuàng)建對象a時(shí)创泄,象 a 確實(shí)是獨(dú)一無二的。 如果 a 變量被聲明在全局作用域下博助,則我們可以在代碼中的任何位置使用這個(gè)變量麻削。樣就
滿足了單例模式的兩個(gè)條件
全局變量會(huì)污染命名空間娇跟, 應(yīng)盡量減少全局變量的使用
使用命名空間可以減少全局變量的數(shù)量萍悴。
var namespace1 = {
a: function(){
alert (1);
},
b: function(){
alert (2);
}
};
使用閉包封裝私有變量
var user = (function () {
var _name = 'wang', _age = '17';
return function () {
console.log(_name, _age);
}
})()
單例模式的缺點(diǎn)
- 可擴(kuò)展性差
- 靈活性差
- js中對象是存儲(chǔ)在內(nèi)存中的一塊中
var a = {'name': 'wang', 'age': 2};
var b = a;
b.name = 'xu';
console.log(a.name); // xu
//a 和 b存儲(chǔ)的都是{'name': 'wang', 'age': 2}在內(nèi)存在存儲(chǔ)地址头遭, 改變b也會(huì)導(dǎo)致a發(fā)生改變