“Hello world”
“单体模式是Javascript中最基本但有最有用的设计模式之一,它可能比其他任何模式都常用。” --出自《Javascript设计模式》
简单的单体模式,是对数据的单体特征、行为的简单封装,非常常用。这种模式提供了一种将代码组织为一个逻辑单元的手段,这个逻辑单元中的代码可以通过单一的变量进行访问。通过确保单体对象只存在一份实例,你就可以确信自己的所有代码使用的都是同样的全局资源。
/* singleton */
缺点:1、容易被别的开发者进行同名方法覆盖,容易混淆对象(污染环境)(在不使用命名空间的情况下)
var Singleton = {
attr1: 'YaDu',
attr2: 23,
methods1: function() {
// TODO
},
methods2: function() {
// TODO
}
}
/* closure */
闭包单体。其中闭包的主要目的是用来保护数据
var Duya = {}
Duya.Singleton = (function() {
let _data = 1;
function _method1() {
// TODO
}
return {
num: _data,
total: _method1,
method: function() {
return '22'
}
}
})()
// 惰性
自我理解:建造基础单体的基础上 ,建立getInstance函数,使得数据在需要用的时候调用
var Duya = {}
Duya.Singleton = (function() {
let _data = 1;
let method= null;
function _method1() {
// TODO
}
function constructor() {
// TODO
}
return {
getInstance: function() {
if(!method) {
method = constructor()
}
return method
}
}
})()
// 分支单体
var Duya = {}
Duya.Singleton = (function() {
// 这里只是举栗子,具体情况是开发环境而定
const def = false
const A = {
};
const B = {
}
return (def) ? A : B
})()