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

总结

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

相关推荐
遂心_7 小时前
JavaScript 函数参数传递机制:一道经典面试题解析
前端·javascript
遂心_8 小时前
深入理解 React Hook:useEffect 完全指南
前端·javascript·react.js
前端Hardy8 小时前
HTML&CSS: 谁懂啊!用代码 “擦去”图片雾气
前端·javascript·css
前端Hardy8 小时前
HTML&CSS:好精致的导航栏
前端·javascript·css
一个不爱写代码的瘦子9 小时前
迭代器和生成器
前端·javascript
幂简集成explinks12 小时前
e签宝签署API更新实战:新增 signType 与 FDA 合规参数配置
后端·设计模式·开源
源猿人12 小时前
企业级文件浏览系统的Vue实现:架构设计与最佳实践
前端·javascript·数据可视化
RoyLin12 小时前
TypeScript设计模式:迭代器模式
javascript·后端·node.js
小桥风满袖14 小时前
极简三分钟ES6 - ES9中for await of
前端·javascript
编程贝多芬14 小时前
Promise 的场景和最佳实践
前端·javascript