当前位置:首页 > 文章列表 > 文章 > 前端 > JavaScript单例模式实现及应用场景解析

JavaScript单例模式实现及应用场景解析

2026-05-19 23:20:32 0浏览 收藏
JavaScript单例模式通过闭包、静态属性或对象字面量等巧妙方式,确保一个类仅存在唯一实例并提供全局访问点,广泛应用于状态管理、日志系统、第三方SDK封装及浏览器API统一管控等场景;它既解决了资源浪费与状态不一致问题,又因隐式依赖和测试困难需谨慎使用——掌握其实现原理与适用边界,才能在轻量项目中高效落地,避免从“省事”变成“埋坑”。

javascript如何实现单例模式_有哪些应用

JavaScript 中实现单例模式的核心是:**确保一个类只有一个实例,并提供全局访问点**。由于 JS 没有原生的类实例控制机制(如 Java 的 private 构造器),我们靠闭包、模块作用域或静态属性来“封住”重复创建的路径。

常见实现方式

1. 简单对象字面量(最轻量,适合配置/工具对象)
直接定义一个对象,天然唯一:

const Config = {
  apiUrl: 'https://api.example.com',
  timeout: 5000,
  setEnv(env) {
    this.env = env;
  }
};

✅ 优点:简洁、无初始化逻辑;❌ 缺点:无法延迟初始化,不支持构造参数。

2. 闭包 + 工厂函数(推荐,支持懒加载和参数)
用闭包保存实例,首次调用才创建:

function createLogger(name) {
  let instance;
  return function() {
    if (!instance) {
      instance = {
        name,
        log(msg) { console.log(`[${this.name}]: ${msg}`); }
      };
    }
    return instance;
  };
}

const getLogger = createLogger('main');
const logger1 = getLogger(); // 创建
const logger2 = getLogger(); // 返回同一实例
console.log(logger1 === logger2); // true

3. ES6 Class + 静态属性(语义清晰,现代写法)
在类上挂载私有静态实例,用 getter 控制访问:

class Database {
  constructor(url) {
    if (Database.instance) {
      return Database.instance;
    }
    this.url = url;
    this.connection = null;
    Database.instance = this;
  }

  connect() {
    if (!this.connection) {
      this.connection = `Connected to ${this.url}`;
    }
    return this.connection;
  }
}

// 使用时需注意:new Database() 每次都返回同一个实例
const db1 = new Database('mysql://localhost');
const db2 = new Database('redis://localhost'); // url 被忽略,仍返回 db1

⚠️ 注意:这种写法中后续构造参数无效,更适合无参或参数一致的场景。若需不同参数初始化,应改用工厂函数封装。

典型应用场景

状态管理器(如轻量级 Store)
整个应用只需一个状态容器,避免多处冗余维护:

  • 全局用户登录状态(userInfo、token、权限列表)
  • 主题配置(darkMode、fontSize、language)
  • 不需要 Redux/Vuex 时的小型项目状态中枢

日志记录器(Logger)
统一格式、等级、输出目标(控制台/上报服务),避免多个 logger 冲突或重复初始化:

  • 自动添加时间戳、模块名前缀
  • 集中控制日志开关(dev-only)、采样率
  • 避免每个组件 new Logger() 造成资源浪费

第三方 SDK 实例封装(如支付、地图、埋点)
SDK 初始化开销大,且多数只允许一个实例:

  • 微信 JSSDK 的 wx 对象需通过 config 初始化一次
  • 高德地图 AMap.Map 实例通常按容器 ID 单例管理
  • 埋点 SDK(如神策、GrowingIO)暴露的 sa 对象本身就是单例

浏览器 API 封装(如 Notification、WebSocket 连接池)
防止重复请求或连接:

  • 全局 WebSocket 管理器:统一处理重连、心跳、消息分发
  • 通知中心:聚合所有业务通知,避免弹窗打架
  • 音频上下文(AudioContext)—— 浏览器建议复用,而非多次 new

注意事项与替代思路

单例虽实用,但易导致隐式依赖、难以单元测试、状态污染。实际开发中可考虑:

  • 优先用模块顶层变量(ESM 默认单例):import 同一文件即得同一对象
  • 用依赖注入(如框架中的 provide/inject)代替硬编码单例
  • 对需要多实例的场景(如多个 WebSocket 地址),改用“注册表模式” + key 索引

基本上就这些。单例不是银弹,关键在“是否真需要全局唯一且共享状态”。用对了省事,滥用则埋坑。

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《JavaScript单例模式实现及应用场景解析》文章吧,也可关注golang学习网公众号了解相关技术文章。

千问如何生成带卡路里食材食谱表?千问如何生成带卡路里食材食谱表?
上一篇
千问如何生成带卡路里食材食谱表?
CSS圆角头像怎么实现?border-radius 50%教程
下一篇
CSS圆角头像怎么实现?border-radius 50%教程
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    516次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    500次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    485次学习
查看更多
AI推荐
  • ljg-skills -
    ljg-skills
    ljg-skills 是李继刚开源的 AI 技能与提示词集合,面向大模型使用者整理了一批可复用的 prompt、角色设定和任务技能模板,适合用于学习提示词设计、搭建个人 AI 工作流和沉淀团队常用智能体能力。
    3015次使用
  • MELO音乐 - AI 音乐生成平台,支持多模态创作能力
    MELO音乐
    MELO音乐是一站式AI视频与音乐制作助手,对标suno, udio的高品质体验。提供伴奏生成、原创写词、无损导出、哼唱识曲、混音变声等全套音频与短视频编辑工具。无论是流行Kpop、电音说唱、民谣古风、摇滚儿歌还是商用轻音乐,MELO为你免费谱曲,轻松做同款!
    2783次使用
  • UniScribe - AI 免费在线音视频转文字平台
    UniScribe
    UniScribe 是一款 AI 音视频转文字与内容整理工具,支持上传音频、视频文件或粘贴 YouTube 链接,自动生成转写文本、摘要、思维导图和关键问题,并支持多格式导出,适合会议记录、课程学习、访谈整理和内容创作复盘。
    2722次使用
  • 剧云 - 免费 AI 智能中文剧本创作平台
    剧云
    剧云是专业中文剧本创作平台,安全稳定运行十余年,集成AI编剧、剧本医生审核、人物小传、剧情关系图、大纲编写、多人协作、Word导入导出、版权管控功能,数据安全防护,轻松高效创作剧本。
    2950次使用
  • 万象有声 - AI 一站式有声内容创作平台
    万象有声
    万象有声,一个专为有声创作者打造的新一代智能有声内容创作平台。平台提供专业的智能拆章、智能画本编辑、AI配音、AI生成音效、后期制作、智能对轨、智能审听等有声创作全流程工具,可以帮助创作者高效、低成本创作出引人入胜的有声作品。立即体验,让有声书制作更简单!
    2900次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码