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的区别的时候,想到这个模式,故学习了单例模式

相关推荐
开心工作室_kaic3 分钟前
ssm068海鲜自助餐厅系统+vue(论文+源码)_kaic
前端·javascript·vue.js
有梦想的刺儿22 分钟前
webWorker基本用法
前端·javascript·vue.js
清灵xmf1 小时前
TypeScript 类型进阶指南
javascript·typescript·泛型·t·infer
WaaTong1 小时前
《重学Java设计模式》之 单例模式
java·单例模式·设计模式
小白学大数据1 小时前
JavaScript重定向对网络爬虫的影响及处理
开发语言·javascript·数据库·爬虫
qq_390161771 小时前
防抖函数--应用场景及示例
前端·javascript
334554322 小时前
element动态表头合并表格
开发语言·javascript·ecmascript
John.liu_Test2 小时前
js下载excel示例demo
前端·javascript·excel
PleaSure乐事2 小时前
【React.js】AntDesignPro左侧菜单栏栏目名称不显示的解决方案
前端·javascript·react.js·前端框架·webstorm·antdesignpro
哟哟耶耶2 小时前
js-将JavaScript对象或值转换为JSON字符串 JSON.stringify(this.SelectDataListCourse)
前端·javascript·json