当前位置: 首页 > news >正文

JS设计模式之单例原型

  • 那么单例模式都有哪些应用场景呢?
  • 如何通过构造函数创建单例
  • 如何使用模块化的方式创建
  • 总结

各位老铁们,今天我们介绍一下JS中单例设计模式,它的特点是确保一个类只有一个实例,并提供一个全局访问点来获取该实例(无论被创建或实例多少次)。接一下从不同角度来实现各场景下的创建过程;

那么单例模式都有哪些应用场景呢?

下面列出常用的几个方面

  • 全局状态管理:例如 Redux 中的 Store。
  • 配置对象:确保配置对象在整个应用中只有一个实例。
  • 数据库连接池:避免重复创建数据库连接。
  • 日志记录器:确保日志记录器是唯一的。

如何通过构造函数创建单例

通过判断instance这个变量是否存在,如果存在或非undefind则返回实例对象,否则将当前类实例的this重新指向instance

class Singleton01 {
        constructor() {
                if (Singleton01.instance) {
                        return Singleton01.instance;
                }
                Singleton01.instance = this;
        }
}

那么实例创建好了,我们通过什么方式来获取呢,可以通过定义一个static静态方法来获取这个实例,这样即能实例唯一性问题;

//这个非常简单即当instance不存在时重新new一个class对象给它,如果存在则直接返回class这个类的instance变量出去即可;
static getInstance() {
        if (!Singleton01.instance) {
                Singleton01.instance = new Singleton01();
        }
        return Singleton01.instance;
}

接下来通过实际示例演示一下,利用constructor创建单例和new出来的对象,以及多次创建是否一致;

let instance1 = Singleton01.getInstance();
let instance2 = Singleton01.getInstance();
let instance3 = new Singleton01();

console.log('instance1 === instance2:',instance1 === instance2); //返回true
console.log('instance1 === instance3:',instance1 === instance3); //返回true

//可以看出两种结果其实构建出来的对象完全一致,指针最终都会指向一个对象

在这里插入图片描述

如何使用模块化的方式创建

  1. 先在全局定义用于接收实例的变量
let instance;
  1. 然后在构造函数中为上面全局变量进行当前实例赋值
let instance02;
//如果不是vue项目那么export default关键字可以不设置,其下面的导入方式也可以改为文件导入方式
export default class Singleton02 {
        constructor() {
                if (instance02) {
                        return instance02;
                }
                instance02 = this;
        }
}
  1. 最后通过导入类来实例,这样创建出来的最终都会指向全局变量instance
import Singleton from 'pattern/singleton_02.js'

let instance4 = new Singleton();
let instance5 = new Singleton();
console.log('instance4 === instance5:', instance4 === instance5); //返回true

总结

单例模式的核心是确保一个类只有一个实例,可以通过构造函数、静态方法、闭包或模块化等方式实现。一般适用于需要全局唯一或单一对象的情况下使用;

相关文章:

  • 【深度学习模型分类】
  • 深入解析系统调用接口(System Call Interface, SCI)
  • 使用C#元组实现列表分组汇总拼接字段
  • Android中解决Button组件英文全部自动大写的问题
  • Oracle临时表空间(基础操作)
  • 科技之光闪耀江城:2025武汉国际半导体产业与电子技术博览会5月15日盛大开幕
  • 基于阿里云可观测产品构建企业级告警体系的通用路径与最佳实践
  • 掌握 PHP 单例模式:构建更高效的应用
  • c语言样式主题 清爽风格 代码色彩 keil风格 适合单片机开发GD32 STM32等 cursor或者vscode 的settings.json文件
  • 51c自动驾驶~合集49
  • IoTDB 断电后无法启动 DataNode,日志提示 Meet error while starting up
  • Linux centos8部署maven3.9.9
  • 「软件设计模式」建造者模式
  • 数据结构——链表
  • HTML 简介
  • AspectJ 下 Advisor 的排序过程
  • 力扣 15.三数之和
  • 日语发音的节拍
  • org.springframework.boot.autoconfigure.AutoConfiguration.imports为什么使用?如何使用?
  • 【嵌入式Linux应用开发基础】opendir函数、readdir函数和closedir函数(二)
  • 今年有望投产里程已近3000公里,高铁冲刺谁在“狂飙”?
  • 李公明︱一周书记:当前科学观中的盲点、危机与……人类命运
  • 中欧金融工作组第二次会议在比利时布鲁塞尔举行
  • 遭“特朗普关税”冲击,韩国今年经济增长预期“腰斩”降至0.8%
  • 商务部就开展加强战略矿产出口全链条管控工作应询答记者问
  • 上海市重大工程一季度开局良好,崇明线等按既定计划加快建设