首页 > web前端 > js教程 > 正文

javascript如何实现设计模式_单例模式和观察者模式如何写

php中文网
发布: 2025-12-08 22:17:02
原创
718人浏览过
单例模式确保类唯一实例并提供全局访问,核心是延迟初始化与实例缓存;观察者模式实现一对多依赖通知,含Subject与Observer角色,需注意内存泄漏与取消订阅。

javascript如何实现设计模式_单例模式和观察者模式如何写

单例模式确保一个类只有一个实例,并提供全局访问点;观察者模式定义对象间一对多依赖,当一个对象状态改变,所有依赖者自动收到通知。两者在 JavaScript 中实现简洁但需注意细节。

单例模式:用闭包或类+静态属性控制实例唯一性

核心是“延迟初始化 + 实例缓存”。避免每次 new 都创建新对象。

  • 传统闭包写法(兼容性好):
    <script></script>
    const Singleton = (function() {
      let instance;
      function createInstance() {
        return {
          data: [],
          add(item) { this.data.push(item); },
          get() { return this.data; }
        };
      }
      return {
        getInstance() {
          if (!instance) {
            instance = createInstance();
          }
          return instance;
        }
      };
    })();
    // 使用
    const a = Singleton.getInstance();
    const b = Singleton.getInstance();
    console.log(a === b); // true
  • ES6 Class 写法(更现代):
    class Logger {
      static #instance;
      constructor() {
        if (Logger.#instance) {
          throw new Error("Already instantiated");
        }
        Logger.#instance = this;
      }
      static getInstance() {
        if (!Logger.#instance) {
          new Logger();
        }
        return Logger.#instance;
      }
      log(msg) { console.log("[LOG]", msg); }
    }
    // 使用
    const logger1 = Logger.getInstance();
    const logger2 = Logger.getInstance();
    console.log(logger1 === logger2); // true

观察者模式:手动实现发布-订阅机制

关键角色:Subject(被观察者)、Observer(观察者)。不依赖第三方库,纯 JS 就能搭出轻量通信总线。

动态WEB网站中的PHP和MySQL:直观的QuickPro指南第2版
动态WEB网站中的PHP和MySQL:直观的QuickPro指南第2版

动态WEB网站中的PHP和MySQL详细反映实际程序的需求,仔细地探讨外部数据的验证(例如信用卡卡号的格式)、用户登录以及如何使用模板建立网页的标准外观。动态WEB网站中的PHP和MySQL的内容不仅仅是这些。书中还提到如何串联JavaScript与PHP让用户操作时更快、更方便。还有正确处理用户输入错误的方法,让网站看起来更专业。另外还引入大量来自PEAR外挂函数库的强大功能,对常用的、强大的包

动态WEB网站中的PHP和MySQL:直观的QuickPro指南第2版 508
查看详情 动态WEB网站中的PHP和MySQL:直观的QuickPro指南第2版
  • 基础版 Subject 类:
    class EventTarget {
      constructor() {
        this.observers = new Map();
      }
      subscribe(event, callback) {
        if (!this.observers.has(event)) {
          this.observers.set(event, new Set());
        }
        this.observers.get(event).add(callback);
      }
      unsubscribe(event, callback) {
        if (this.observers.has(event)) {
          this.observers.get(event).delete(callback);
        }
      }
      notify(event, data) {
        if (this.observers.has(event)) {
          for (const cb of this.observers.get(event)) {
            cb(data);
          }
        }
      }
    }
    // 使用示例
    const bus = new EventTarget();
    bus.subscribe("user-login", (user) => console.log("欢迎", user.name));
    bus.subscribe("user-login", (user) => console.log("更新头像"));
    bus.notify("user-login", { name: "张三" });
  • 进阶建议:
    – 用 WeakMap 存 observer 可避免内存泄漏(尤其 DOM 元素作为 observer 时)
    – 加入 once 方法支持一次性监听
    – notify 支持异步(如 Promise.all)避免阻塞主线程

实际用在哪?别硬套,看场景

单例适合:全局配置管理、日志器、状态仓库(如简易版 store)、WebSocket 连接实例。
观察者适合:组件通信(尤其无框架时)、表单联动、事件解耦(比如按钮点击后多个模块响应)、状态变更广播。

基本上就这些。两种模式都不复杂,但容易忽略边界情况——比如单例没防 new,观察者没做取消订阅,上线后可能悄悄吃内存。

立即学习Java免费学习笔记(深入)”;

以上就是javascript如何实现设计模式_单例模式和观察者模式如何写的详细内容,更多请关注php中文网其它相关文章!

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号