JS设计模式之单例原型

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

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

下面列出常用的几个方面

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

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

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

javascript 复制代码
class Singleton01 {
        constructor() {
                if (Singleton01.instance) {
                        return Singleton01.instance;
                }
                Singleton01.instance = this;
        }
}

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

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

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

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

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

总结

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

相关推荐
liangshanbo12151 小时前
写好 React useEffect 的终极指南
前端·javascript·react.js
earthzhang20211 小时前
第3讲:Go垃圾回收机制与性能优化
开发语言·jvm·数据结构·后端·性能优化·golang
纵有疾風起2 小时前
C++——类和对象(3)
开发语言·c++·经验分享·开源
Full Stack Developme3 小时前
java.text 包详解
java·开发语言·python
文火冰糖的硅基工坊3 小时前
[嵌入式系统-135]:主流AIOT智能体开发板
开发语言·嵌入式·cpu
_院长大人_3 小时前
el-table-column show-overflow-tooltip 只能显示纯文本,无法渲染 <p> 标签
前端·javascript·vue.js
SevgiliD3 小时前
el-table中控制单列内容多行超出省略及tooltip
javascript·vue.js·elementui
yudiandian20144 小时前
02 Oracle JDK 下载及配置(解压缩版)
java·开发语言
要加油哦~4 小时前
JS | 知识点总结 - 原型链
开发语言·javascript·原型模式
鄃鳕4 小时前
python迭代器解包【python】
开发语言·python