单例模式

2020-01-10  本文已影响0人  旧时袋

2020.01.10 晚 22:01

问题

我们从下面3个问题去对单例模式进行探讨

为什么需要单例模式?

举个 ”栗子”
游戏中主角,通常只能有一个。那么我们在写代码的时候,就得保证只有一个主角类,而且这个类只能被实例一次。那么就得用到单例模式。

单例模式有什么用?

保证某个类只能被实例一次

如何实现单例模式?

实现思路

使用闭包创建一个变量来存储已经实例的类
之后只要每次实例类时,判断该变量是否有值即可
如果有值就将变量的值返回,如果没有就实例类并返回
提示:闭包中的变量的值会在该次代码运行中一直存在

具体实现代码

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)

拓展例子:模拟登录框

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()
// login1.hide()

// 另一个页面中调用登录框
let login2 = LoginForm.getInstance()
login2.show()
上一篇 下一篇

猜你喜欢

热点阅读