news 2026/6/9 20:54:30

常见的设计模式

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
常见的设计模式

1. 事件发射器

是一种 发布-订阅 (publish,subcription) 模型的实现

事件中心、事件发射器

本质是Map存储 事件名→回调函数集合

这样彼此都不知道对方存在,都是被 事件中心 单向关联,实现解耦

{ "data": [fn1, fn2], "click": [fnA], "error": [fnX, fnY, fnZ] }

on 注册:将函数放入集合

emit 遍历集合,依次执行回调

emit(eventName, payload) { for (const fn of listeners[eventName]) { fn(payload); } }

截图工具多语言中的事件发射器

2. 观察者模式

被观察者状态变化时通知所有观察者,触发update

之间通过 subjects 通信,需要维护观察者列表并实现 广播,即调用观察者的 update 回调,所以解耦合得并不是很彻底

// 被观察者:维护状态 + 维护观察者 class Subject { constructor() { this.observers = []; this.state = null; } setState(value) { this.state = value; this.notify(value); } addObserver(observer) { this.observers.push(observer); } removeObserver(observer) { this.observers = this.observers.filter(o => o !== observer); } notify(value) { this.observers.forEach(observer => observer.update(value)); } } // 观察者:需要有 update 方法 class Observer { update(value) { console.log("收到更新:", value); } } // 使用 const subject = new Subject(); const obs1 = new Observer(); const obs2 = new Observer(); subject.addObserver(obs1); subject.addObserver(obs2); subject.setState(123); // 输出:两次 “收到更新:123”

还有例如 useForm 中对表单状态 _formState 更新后通知相关组件的实现就是内部维护了一个观察者subjects

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 9:49:53

19、深入探索 Azure 存储:表、队列、文件和 Blob

深入探索 Azure 存储:表、队列、文件和 Blob 1. 表存储中的数据查询 要在表存储中查询数据,你需要一个简单的应用程序(可以是控制台应用程序)以及该服务的 SDK。同时,你还需要一个 Azure 存储实例,它可以是在 Azure 中预配置的,也可以是本地的(如果你安装了存储模拟器…

作者头像 李华
网站建设 2026/6/10 15:55:59

20、深入探索 Azure 存储与事件中心服务

深入探索 Azure 存储与事件中心服务 1. Azure 存储的强大功能 Azure 存储是一项极为灵活且实用的服务,涵盖了表存储、队列存储、文件存储和 Blob 存储等多种类型,能满足从文件存储到日志数据库等多样化的需求。 1.1 Blob 存储的额外特性 Blob 存储有一项新颖且实用的特性…

作者头像 李华
网站建设 2026/6/10 15:54:14

2、Java语言基础全面解析

Java语言基础全面解析 1. 评估测试与答案 评估测试题目 :涵盖了各类Java知识点的选择题,如有效声明、Map操作、关键字用途、抽象类特性、访问修饰符顺序、线程方法调用等,还涉及代码结果判断、运算符计算、数组操作等内容。 | 题目编号 | 题目内容 | 选项 | 正确答案 | …

作者头像 李华
网站建设 2026/6/10 12:46:36

9、Java线程编程全解析

Java线程编程全解析 1. 线程基础概念 Java线程是让单台Java虚拟机(JVM)看起来像多台机器同时运行的一种机制。通常,这只是一种假象,因为实际上只有一个JVM和一个CPU,CPU在JVM的各个线程之间切换,给人一种有多个CPU在同时运行的感觉。JVM线程在后台默默工作,负责监听用…

作者头像 李华
网站建设 2026/6/10 5:14:07

11、Java I/O与流:全面解析

Java I/O与流:全面解析 1. 文本、UTF与Unicode 在计算机早期,内存昂贵,每个字符用单字节表示,ASCII标准规定了256种位组合对应的字符。但它只能涵盖美国和英语字符,许多其他语言的字符被忽略。于是,很多群体开发了自己的字节到字符的映射标准,这导致处理文件时必须知道…

作者头像 李华
网站建设 2026/6/9 22:47:42

13、Java布局管理器全解析:从基础到高级应用

Java布局管理器全解析:从基础到高级应用 1. 布局管理器概述 在Java中,设计复杂的图形用户界面(GUI)时,布局管理器起着至关重要的作用。它们帮助我们控制GUI组件的大小和位置,使应用程序更易于理解和使用。Java的 java.awt 包提供了五种标准的布局管理器:Flow、Grid、…

作者头像 李华