1. 单例模式
1.1 单例模式介绍
1.2 单例模式类图
传统 UML 类图

1.2 单例模式演示
说明
- 单例模式需要用到 java 的特性(
private
)
- ES6 中没有(
TypeScript
除外)
- 只能用 java 代码来演示 UML 图的内容
java 代码演示
public class SingleObject {
private SingleObject() {
}
private SingleObject instance = null;
public SingleObject getInstance() {
if (instance == null) {
instance = new SingleObject();
}
return instance;
}
public void login(username, password) {
System.out.println("login...");
}
}
public class SingletonPatternDemo {
public static void main(String[] args) {
SingleObject object = SingleObject.getInstance();
object.login();
}
}
class SingleObject {
login() {
console.log('login...')
}
...
}
SingleObject.getInstance = (function () {
let instance
return function () {
if (!instance) {
instance = new SingleObject();
}
return instance
}
})()
let obj1 = SingleObject.getInstance()
obj1.login()
let obj2 = SingleObject.getInstance()
obj2.login()
console.log(obj1 === obj2)
let obj3 = new SingleObject()
obj3.login()
console.log(obj1 === obj3)
1.3 单例模式场景
1.3.1 jQuery 只有一个 $
jQuery 的全局函数是 $,只有一个
- 如果一个页面中错误的将jQuery 代码引用好几遍,按理说应该有好几个或重复的 $,但是 jQuery 内部会处理
如果检测到内部有 jQuery,就会直接返回,如果没有就会进行初始化操作
多次初始化的问题
消耗性能
- 内部代码出现bug(比如
多次渲染、多次统计
等等)
if (window.jquery != null) {
return window.jQuery
} else {
}
1.3.2 模拟登录框
class LoginForm {
constructor() {
this.state = 'hide'
}
show() {
if (this.state === 'show') {
alert('已经显示')
return
}
this.state = 'show'
console.log('登录框已显示')
}
hide() {
if (this.state === 'hide') {
alert('已经隐藏')
return
}
this.state = 'hide'
console.log('登录框已隐藏')
}
}
LoginForm.getInstance = (function() {
let instance
return function() {
if(!instance) {
instance = new LoginForm();
}
return instance
}
})()
let login1 = LoginForm.getInstance()
login1.show()
let login2 = LoginForm.getInstance()
login2.hide()
console.log(login1 === login2)
1.3.3 vuex 和 redux 中的 store
- 业务复杂度很高,每一块业务场景下获取 store,都必须是
完全一样
的,这样才能导致业务的数据同步
- 模块A和模块B获取的 store 必须是完全一样的,可以
共享
的
- 如果模块A和模块B获取的 store 不一致,那模块A和模块B就不能通过 store 来进行
数据共享
和数据传递
,所以是单例模式
1.4 单例模式设计原则验证
- 符合
单一职责
原则,只实例化唯一的对象
- 没法具体开放封闭原则,但是
绝对不违反开放封闭原则