javascript设计模式---单例模式

JavaScript设计模式---单例模式

单例模式又称为单体模式,并提供一个访问它的全局访问点,也就是说,第二次使用同一个类创建的对象的时候,应该得到和第一次创建的对象完全相同的对象

特点

  1. 一个类只能生成一个实例对象
  2. 提供一个全局访问点来获取这个实例

案例

  1. window和document
  2. Vuex,Redux和Router
  3. 全局loading

缺点

确保在整个应用中,只有一个实例存在,而且该实例需要被全局访问时。但是使用单例模式,因为可能会引入全局状态,增加代码的复杂度和耦合性

实现

  1. 构造函数
javascript 复制代码
let singleDemo;
function SingleDemo() {
  if (!singleDemo) {
    singleDemo = this;
  }
  return singleDemo;
}
SingleDemo.prototype.show = function () {
  console.log("我是单例模式");
};
const single1 = new SingleDemo();
const single2 = new SingleDemo();
console.log(single1 === single2);
  1. 使用类的静态属性
javascript 复制代码
class Singleton {
  static instance;
  constructor() {
    if (!Singleton.instance) {
      Singleton.instance = this;
    }
    return Singleton.instance;
  }
}
const instance1 = new Singleton();
const instance2 = new Singleton();
console.log(instance1 === instance2); // true
  1. 闭包
javascript 复制代码
const Singleton = (function () {
  let instance;
  function createInstance() {
    // 实例化逻辑
    return {
      // 实例属性和方法
    };
  }
  return {
    getInstance: function () {
      if (!instance) {
        instance = createInstance();
      }
      return instance;
    },
  };
})();
const instance1 = Singleton.getInstance();
const instance2 = Singleton.getInstance();
console.log(instance1 === instance2); // true

应用场景

  1. window和document全局变量,是单例
  2. es6中的module模块特性,通过import/export导出模块的变量是单例。
  3. Vuex维护的全局状态是单例的。

ps: 后续还会补充,在学习vuex和eventbus的区别的时候,想到这个模式,故学习了单例模式

相关推荐
卷帘依旧22 分钟前
JavaScript 闭包经典问题:为什么输出 10 次 i=10
javascript
柳杉40 分钟前
Three.js × Blender:从建模到 Web 3D 的完整工作流深度解析
前端·javascript·数据可视化
用户806138166592 小时前
发布为一个 npm 包
前端·javascript
TT_哲哲3 小时前
小程序双模式(文件 / 照片)上传组件封装与解析
前端·javascript
从文处安3 小时前
「九九八十一难」从回调地狱到异步秩序:深入理解 JavaScript Promise
前端·javascript
进击的尘埃3 小时前
Node.js 子进程管理:child_process 模块的正确打开方式
javascript
angerdream3 小时前
最新版vue3+TypeScript开发入门到实战教程之Pinia详解
前端·javascript·vue.js
怜悯3 小时前
uniapp 如何实现google登录-安卓端
前端·javascript
TT_哲哲3 小时前
小程序解析字符串拼接多图 点击放大展示
前端·javascript
workflower3 小时前
设计模式的分类
设计模式·集成测试·软件工程·软件构建·软件需求·结对编程