前端开发设计模式——组合模式
目录
一、组合模式的定义和特点
1.定义
2.特点:
二、组合模式的实现方式
1.定义抽象组件类
2.创建叶节点类
3.创建组合类:
三、组合模式的应用场景
1.界面布局管理
2.菜单系统构建
3.组件库开发
四、组合模式的优点
1.简化客户端代码
2.增强代码的可拓展性
3.清晰的层次结构表示
五、组合模式的缺点
1.限制组件的特异性
2.可能导致过度设计
六、组合模式的注意事项
1.接口设计的合理性
2.性能考虑
3.避免过度抽象
一、组合模式的定义和特点
1.定义
组合模式是一种结构型设计模式,它将对象组合成树形结构以表示 “部分 - 整体” 的关系。在前端开发中,这种模式允许将单个的 UI 元素(如按钮、文本框等叶节点)和由多个元素组成的复合元素(如包含多个子元素的面板等组合对象)以统一的方式进行处理。
2.特点:
统一的操作接口:无论是单个的叶节点对象还是包含多个子对象的组合对象,都实现相同的接口或继承自相同的抽象类,对外提供一致的操作方法。
递归组合:组合对象可以包含其他组合对象或叶节点对象,形成递归的树形结构。这种结构能够自然地表示前端界面中的嵌套关系,如菜单的多级嵌套或者组件的多层嵌套布局。
透明性:客户端不需要知道操作的对象是叶节点还是组合对象,都可以调用相同的方法进行操作,如渲染操作可以在单个组件和包含多个组件的容器上以相同的方式执行。
二、组合模式的实现方式
1.定义抽象组件类
创建一个抽象类或接口,定义叶节点和组合对象共有的方法。例如:
// 抽象组件类
class Component {constructor(name) {this.name = name;}// 抽象的操作方法,例如渲染render() {throw new Error('render method must be implemented in subclasses');}
}
2.创建叶节点类
叶节点类继承自抽象组件类,实现具体的操作方法。以一个简单的文本叶节点为例:
class Leaf extends Component {constructor(name) {super(name);}render() {return `<span>${this.name}</span>`;}
}
3.创建组合类:
组合类也继承自抽象组件类,内部包含一个子组件的列表,并实现管理子组件(添加、删除等)和操作子组件(如渲染所有子组件)的方法。例如:
class Composite extends Component {constructor(name) {super(name);this.children = [];}add(child) {this.children.push(child);}remove(child) {const index = this.children.indexOf(child);if (index!== - 1) {this.children.splice(index, 1);}}render() {let result = `<div>${this.name}`;for (const child of this.children) {result += child.render();}result += '</div>';return result;}
}
三、组合模式的应用场景
1.界面布局管理
在构建前端页面布局时,如构建一个包含头部、主体、侧边栏等多个部分的页面,每个部分可以看作是一个组合对象,其中头部可能包含导航菜单(组合对象)和搜索框(叶节点)等。通过组合模式,可以方便地构建和管理这种复杂的布局结构。
2.菜单系统构建
对于多级菜单结构,主菜单可以是一个组合对象,子菜单也可以是组合对象或者叶节点(最底层的菜单项)。组合模式能够轻松地处理菜单的展开、折叠以及导航功能,并且方便添加或删除菜单项。
3.组件库开发
在设计前端组件库时,组件之间往往存在嵌套关系。例如,一个表单组件可能包含多个输入框、下拉框等组件。使用组合模式可以将这些组件组织起来,使得组件库的结构更加清晰,方便开发者使用和扩展。
四、组合模式的优点
1.简化客户端代码
客户端不需要区分操作的是单个元素还是组合元素,统一调用相同的方法。这减少了代码中的条件判断,使代码更加简洁、易于理解和维护。例如,在渲染整个页面时,不管是单个的文本元素还是包含多个子元素的复杂布局区域,都可以使用相同的渲染函数。
2.增强代码的可拓展性
可以方便地添加新的叶节点或组合对象类型。只要新的类型遵循抽象组件类定义的接口,就可以无缝地集成到现有的树形结构中。这对于前端项目不断发展,需要添加新的 UI 元素或布局结构时非常有利。
3.清晰的层次结构表示
组合模式以树形结构清晰地展示了对象之间的关系,这有助于开发人员理解前端界面的整体架构,便于进行代码的组织和管理,尤其是在处理复杂的界面布局或嵌套组件关系时。
五、组合模式的缺点
1.限制组件的特异性
由于所有的组件(叶节点和组合对象)都要遵循相同的接口,对于一些具有特殊行为的组件,可能需要进行一些额外的设计和适配。例如,某些特殊的 UI 元素可能需要独特的事件处理方式,这可能与组合模式的通用接口存在一定的冲突。
2.可能导致过度设计
在简单的前端结构场景中,如果强行使用组合模式,可能会引入不必要的复杂性。例如,对于一个只有几个简单元素的小型界面,使用组合模式可能会增加过多的抽象层次和代码结构,反而使代码变得臃肿
六、组合模式的注意事项
1.接口设计的合理性
在定义抽象组件类的接口时,要充分考虑到叶节点和组合对象的共性和差异。接口应该包含足够通用的方法来满足大多数场景的需求,但也不能过于复杂,以免影响组件的实现和使用效率。
2.性能考虑
在处理大型的树形结构(如包含大量嵌套组件的复杂页面)时,要注意操作的性能。例如,渲染一个深度嵌套的组件树可能会消耗较多的时间和资源,需要考虑采用优化策略,如懒加载、虚拟 DOM 等技术来提高性能。
3.避免过度抽象
要根据实际的前端开发需求来决定是否使用组合模式,避免为了使用模式而使用模式,造成不必要的代码复杂性。如果简单的结构可以通过更直接的方式实现,就不需要强行套用组合模式。
相关文章:
前端开发设计模式——组合模式
目录 一、组合模式的定义和特点 1.定义 2.特点: 二、组合模式的实现方式 1.定义抽象组件类 2.创建叶节点类 3.创建组合类: 三、组合模式的应用场景 1.界面布局管理 2.菜单系统构建 3.组件库开发 四、组合模式的优点 1.简化客户端代码 2.增…...
初探OceanBase 4.x单机环境下如何进行主备架构搭建
本文来自OceanBase 用户的体验分享 (以下简称 OB),已经开源了3年左右,其间从3.x版本演进至4.x版本,发生了许多变化。对一个DBer而言,最为关切的是如何高效运用OB,以及是否能实现如同应用MySQL般…...
python 实现Edmonds-Karp算法
Edmonds-Karp算法介绍 Edmonds-Karp算法是一种用于解决最大流问题的算法,在计算机科学中广泛应用。以下是关于Edmonds-Karp算法的详细解释: 算法概述 Edmonds-Karp算法是基于Ford-Fulkerson方法的改进,它通过广度优先搜索(BFS&…...
【牛客刷题实战】BC120 争夺前五名
大家好,我是小卡皮巴拉 文章目录 目录 牛客题目: BC120 争夺前五名 题目描述 输入描述: 输出描述: 示例1 示例2 解题思路: 具体思路: 题目要点: 完整代码: 兄弟们共…...
WMS 智慧仓储管理系统的可视化管理_SunWMS
【大家好,我是唐Sun,唐Sun的唐,唐Sun的Sun。一站式数智工厂解决方案服务商】 WMS 智慧仓储管理系统的可视化管理主要表现在以下几个方面: 首先是库存可视化。通过系统,仓库管理人员能够以直观的图表、图形等形式清晰地…...
动态代理代码示例
理解动态代理 动态代理的核心在于代理对象的创建和方法调用是在运行时动态发生的,而不是在编译时就已经确定的性能监控、事务管理、日志记录通常需要使用代理对象对目标对象的功能进行增强为什么JDK动态代理只能代理有接口的类? 因为Proxy.newProxyIns…...
SpringBoot+Activiti7工作流使用进阶实例-高亮显示BPMN流程图( SpringBoot+Activiti+mybatis+shiro实现)
文章目录 说明绘制流程图排他网关设置任务节点设置创建工程修改 pom.xml 文件准备数据库的表和测试数据修改 application.yml 文件配置静态资源Shiro 相关配置ShiroConfiguration.javaMyShiroRealm.java流程控制器添加静态的资源和模板页面运行结果截图源码地址说明 使用 Spri…...
C#使用Lazy<T>提高性能
以下是一些适合使用Lazy<T>的场景: 单例模式 在实现单例模式时,Lazy<T>是非常有用的。如前面提到的示例,它可以确保单例对象在首次被访问时才进行创建,同时在多线程环境下也能保证正确的行为。这种方式比传统的双重检…...
创建读取比特币1P类型地址
创建读取比特币1P类型地址 比特币的地址类型有多种,其中 P2TR(Pay-to-Taproot)地址是基于最近的升级(Taproot)引入的一个新类型。本文将介绍如何创建和读取比特币的 1P 类型地址,主要通过 JavaScript 和相…...
从零开始Hadoop集群环境搭建
目录 1. Centos7.5硬件配置1.1 创建虚拟机1.2 虚拟机系统设置 2. IP地址和主机名称配置3. 软件配置3.1 安装 epel-release3.2 卸载虚拟机自带的JDK3.3 克隆虚拟机3.4 修改克隆虚拟机的IP3.5 JDK安装3.6 Hadoop安装 4. Hadoop目录结构 1. Centos7.5硬件配置 1.1 创建虚拟机 1.2…...
Copley耐环境伺服驱动器 极端环境下高精度控制解决方案
全球工业环境的日益复杂多变,对伺服驱动器的要求不再局限于基本的性能参数,而是在极端环境下的稳定性与可靠性。Copley耐环境伺服驱动器以卓越的性能和出色的环境适应性,为工业自动化领域的高精度控制提供了可靠的解决方案。 一、多样化的产…...
前端的全栈混合之路Meteor篇:分布式数据协议DDP深度剖析
本文属于进阶篇,并不是太适合新人阅读,但纯粹的学习还是可以的,因为后续会实现很多个ddp的版本用于web端、nodejs端、安卓端和ios端,提前预习和复习下。ddp协议是一个C/S架构的协议,但是客户端也同时可以是服务端。 什…...
基于Zynq SDIO WiFi移植一(支持2.4/5G)
基于SDIO接口的WIFI,在应用上,功耗低于USB接口,且无须USB Device支持,满足某些应用场景 1 硬件连接 2 Vivado工程配置 3 驱动编译 3.1 KERNRL CONFIG (build ENV) 修改 export KERNELPATH<path of kernel header>export T…...
数据结构与算法篇(刷题篇 - 链表)
目录 1. 反转链表(简单) 1.1. 题目描述 1.2. 解题思路 方法一:迭代(推荐使用) 方法二:递归(扩展思路) 方法三:使用栈解决 方法四:双链表求解 2. 链表内…...
TinyAgent: 从零开始构建最小化Agent系统
引言 随着大模型(LLM)的崛起,特别是ChatGPT等大模型的广泛应用,基于LLM的系统越来越受欢迎。然而,尽管大模型具备强大的生成能力和推理能力,它们在处理某些专有领域或实时问题时仍然存在局限性。因此&#…...
Android Studio New里面没有New Flutter Project
跟着Flutter中文网的配置教程,安装好了flutter,在Android studio里面也安装了dart和flutter的插件。重启后还是在FIle->New里面没有显示New Flutter Project。 反复卸载重装dart和flutter插件好几次,依然没有效果。 原来是没有把Android APK Suppor…...
linux信号 | 学习信号四步走 | 透析信号是如何被处理的?
前言:本节内容讲述linux信号的捕捉。 我们通过前面的学习, 已经学习了信号的概念, 信号的产生, 信号的保存。 只剩下信号的处理。 而信号的处理我们应该着重注意的是第三种处理方式——信号的捕捉。 也就是说, 这篇文章…...
mysql语句执行过程
具体流程如下: 1】当客户端的SOL发送到MySQL时,首先是到达服务器层的连接器,连接器会对你此次发起的连接进行权限校验,以此来获取你这个账号拥有的权限。当你的账号或密码不正确时,会报用户错误。连接成功如果后续没有任何操作&am…...
最新版本SkyWalking【10.1.0】部署
这里写目录标题 前言前置条件启动Skywalking下载解压启动说明 集成Skywalking Agent下载Agent在IDEA中添加agent启动应用并访问SpringBoot接口 说明 前言 基于当前最新版10.1.0搭建skywalking 前置条件 装有JDK11版本的环境了解SpringBoot相关知识 启动Skywalking 下载 地…...
WSL2 中配置桥接模式、虚拟交换机及固定 IP
WSL2 中配置桥接模式、虚拟交换机及固定 IP 一、创建虚拟交换机1.1 使用 Hyper-V 管理器创建虚拟交换机1.2 使用 PowerShell 创建虚拟交换机 二、更新 WSL 配置三、设置 WSL2 中的静态 IP、网关和 DNS3.1 编辑网络配置文件3.2 应用网络配置3.3 测试网络连接 四、重启 WSL 在使用…...
【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型
摘要 拍照搜题系统采用“三层管道(多模态 OCR → 语义检索 → 答案渲染)、两级检索(倒排 BM25 向量 HNSW)并以大语言模型兜底”的整体框架: 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后,分别用…...
python打卡day49
知识点回顾: 通道注意力模块复习空间注意力模块CBAM的定义 作业:尝试对今天的模型检查参数数目,并用tensorboard查看训练过程 import torch import torch.nn as nn# 定义通道注意力 class ChannelAttention(nn.Module):def __init__(self,…...
CMake基础:构建流程详解
目录 1.CMake构建过程的基本流程 2.CMake构建的具体步骤 2.1.创建构建目录 2.2.使用 CMake 生成构建文件 2.3.编译和构建 2.4.清理构建文件 2.5.重新配置和构建 3.跨平台构建示例 4.工具链与交叉编译 5.CMake构建后的项目结构解析 5.1.CMake构建后的目录结构 5.2.构…...
关于nvm与node.js
1 安装nvm 安装过程中手动修改 nvm的安装路径, 以及修改 通过nvm安装node后正在使用的node的存放目录【这句话可能难以理解,但接着往下看你就了然了】 2 修改nvm中settings.txt文件配置 nvm安装成功后,通常在该文件中会出现以下配置&…...
SpringBoot+uniapp 的 Champion 俱乐部微信小程序设计与实现,论文初版实现
摘要 本论文旨在设计并实现基于 SpringBoot 和 uniapp 的 Champion 俱乐部微信小程序,以满足俱乐部线上活动推广、会员管理、社交互动等需求。通过 SpringBoot 搭建后端服务,提供稳定高效的数据处理与业务逻辑支持;利用 uniapp 实现跨平台前…...
拉力测试cuda pytorch 把 4070显卡拉满
import torch import timedef stress_test_gpu(matrix_size16384, duration300):"""对GPU进行压力测试,通过持续的矩阵乘法来最大化GPU利用率参数:matrix_size: 矩阵维度大小,增大可提高计算复杂度duration: 测试持续时间(秒&…...
AI编程--插件对比分析:CodeRider、GitHub Copilot及其他
AI编程插件对比分析:CodeRider、GitHub Copilot及其他 随着人工智能技术的快速发展,AI编程插件已成为提升开发者生产力的重要工具。CodeRider和GitHub Copilot作为市场上的领先者,分别以其独特的特性和生态系统吸引了大量开发者。本文将从功…...
OPenCV CUDA模块图像处理-----对图像执行 均值漂移滤波(Mean Shift Filtering)函数meanShiftFiltering()
操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C11 算法描述 在 GPU 上对图像执行 均值漂移滤波(Mean Shift Filtering),用于图像分割或平滑处理。 该函数将输入图像中的…...
Java线上CPU飙高问题排查全指南
一、引言 在Java应用的线上运行环境中,CPU飙高是一个常见且棘手的性能问题。当系统出现CPU飙高时,通常会导致应用响应缓慢,甚至服务不可用,严重影响用户体验和业务运行。因此,掌握一套科学有效的CPU飙高问题排查方法&…...
使用LangGraph和LangSmith构建多智能体人工智能系统
现在,通过组合几个较小的子智能体来创建一个强大的人工智能智能体正成为一种趋势。但这也带来了一些挑战,比如减少幻觉、管理对话流程、在测试期间留意智能体的工作方式、允许人工介入以及评估其性能。你需要进行大量的反复试验。 在这篇博客〔原作者&a…...
