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

相关推荐
ZC跨境爬虫6 小时前
跟着 MDN 学JavaScript day_7:数学运算与逻辑判断实战测试
开发语言·前端·javascript·学习·ecmascript
凌云拓界7 小时前
文件管理:让AI安全操作你的电脑 ——CogitoAgent开发实战(三)
javascript·人工智能·架构·开源·node.js
凌云拓界7 小时前
联网能力:让AI看见更广阔的世界 ——CogitoAgent开发实战(四)
javascript·人工智能·架构·node.js·创业创新
HYCS8 小时前
用pixi.js实现fabric.js(六):从线性代数的角度理解编辑器交互
前端·javascript·canvas
you45809 小时前
学成在线--day02 CMS前端开发(含Vue基础知识得回顾)
前端·javascript·vue.js
想吃火锅10059 小时前
【leetcode】1.两数之和js版
javascript·算法·leetcode
xiaofeichaichai9 小时前
虚拟 DOM
前端·javascript·vue.js
初一初十9 小时前
vue3实现的纯前端护肤品商城网站
前端·javascript·vue.js·前端框架
ANnianStriver10 小时前
PetLumina 07 — 宠物管理升级与 JavaScript 大数精度修复
开发语言·javascript·ai编程·宠物
初一初十11 小时前
vue3茶叶商城网站vue网页vuejs前端
前端·javascript·vue.js·vscode·前端框架