美文网首页
单例模式

单例模式

作者: 我的钱包瘪瘪的 | 来源:发表于2020-03-11 09:13 被阅读0次

单例模式

1. 介绍

2. uml类图

3. demo代码

4. 经典应用场景

介绍

  1. 保证全局只存在一个实例

  2. 实现: 判断实例是否存在,存在则直接返回,不存在就创建了再返回

uml类图

demo代码

    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.show()
    
    // login1 === login2, 代码生成的是同一个实例
    console.log('login1 === login2 :>> ', login1 === login2);

经典应用场景

  1. jquery的$存在
if (window.jQuery != null) {
    return window.jQuery
} else {
    // 初始化...
}
  1. 购物车(和登录框类似)

  2. vuex 和 redux 中的store

  3. element的弹窗组件

https://github.com/ElemeFE/element/blob/dev/packages/message-box/src/main.js#L79

相关文章

  • 【设计模式】单例模式

    单例模式 常用单例模式: 懒汉单例模式: 静态内部类单例模式: Android Application 中使用单例模式:

  • Android设计模式总结

    单例模式:饿汉单例模式://饿汉单例模式 懒汉单例模式: Double CheckLock(DCL)实现单例 Bu...

  • 2018-04-08php实战设计模式

    一、单例模式 单例模式是最经典的设计模式之一,到底什么是单例?单例模式适用场景是什么?单例模式如何设计?php中单...

  • 设计模式之单例模式详解

    设计模式之单例模式详解 单例模式写法大全,也许有你不知道的写法 导航 引言 什么是单例? 单例模式作用 单例模式的...

  • Telegram开源项目之单例模式

    NotificationCenter的单例模式 NotificationCenter的单例模式分析 这种单例模式是...

  • 单例模式Java篇

    单例设计模式- 饿汉式 单例设计模式 - 懒汉式 单例设计模式 - 懒汉式 - 多线程并发 单例设计模式 - 懒汉...

  • IOS单例模式的底层原理

    单例介绍 本文源码下载地址 1.什么是单例 说到单例首先要提到单例模式,因为单例模式是单例存在的目的 单例模式是一...

  • 单例

    iOS单例模式iOS之单例模式初探iOS单例详解

  • 单例模式

    单例模式1 单例模式2

  • java的单例模式

    饿汉单例模式 懒汉单例模式

网友评论

      本文标题:单例模式

      本文链接:https://www.haomeiwen.com/subject/flifjhtx.html