当前位置: 首页 > backend >正文

React 5 种组件提取思路与实践

在开发时,经常遇到一些高度重复但略有差异的 UI 模式,此时我们当然会把组件提取出去,但是组件提取的方式有很多,怎么根据不同场景选取合适的方式呢?尤其时在复杂的业务场景中,组件提取的思路影响着着代码的可维护性、可读性以及扩展性。本文将以一个[详情]组件为例,探讨 5 种不同的 React 组件提取思路,分析它们的适用场景与实现技巧。
在这里插入图片描述

一、直接实现

// 全部写在一个组件中
const ProductDetail = ({ productItem }) => (<div className="prose"><section><h2>小标题1</h2><p>{productItem.content}</p></section>{/* 重复类似结构 */}</div>
);

问题分析

  • 重复代码量随区块增加线性增长
  • 修改样式需要全局搜索替换
  • 难以应对需求变化(如新增内容区块)

这种实现方式虽然简单,但当内容结构复杂或者频繁变化时,会导致代码的重复度过高,难以维护。

二、进化之路:5 种组件提取模式

模式 1:配置驱动式(Config-Driven)

又名数据驱动模式、JSON Schema 模式

核心思想 ​​:将 UI 结构抽象为数据配置,实现 UI = f(config)

const ProductContent = ({ sections }) => (<div className="prose">{sections.map((section) => (<section key={section.title}><h2>{section.title}</h2>{renderContent(section)}</section>))}</div>
);

优势

  • 动态生成能力:可以通过修改配置文件快速调整页面内容。
http://www.xdnf.cn/news/1393.html

相关文章:

  • Linux系统编程---精灵进程与守护进程
  • LInux平均负载
  • LangGraph vs. OpenAI Agent SDK – 哪个代理构建框架更适合您?
  • c++ 互斥锁
  • react的ant-design-pro框架左侧菜单修改为动态路由
  • 【HFP】蓝牙HFP协议来电处理机制解析
  • 手机端touch实现DOM拖拉功能
  • C# 全局 Mutex 是否需使用 `Global\` 前缀
  • 硬核科普丨2025年安全、高效网络准入控制系统深度解析
  • Python flask入门
  • 代码随想录训练营第39天 || 198. 打家劫舍 213. 打家劫舍 II 337. 打家劫舍 III
  • Prometheus 系统化学习计划-总纲
  • Spring Boot 中处理 JSON 数值溢出问题:从报错到优雅解决
  • 商汤绝影生成式AI汽车新品亮相上海车展,引领AI汽车创新潮流
  • gem5教程第三章 向配置脚本添加缓存
  • 数据结构的学习(1)二分查找,利用二分查找找局部最小值,选择排序,冒泡排序,插入排序,位运算的基础知识
  • 我们为什么要选用微服务架构
  • 云计算领域需掌握的核心技术
  • 4.RabbitMQ - 延迟消息
  • 基于自主大型语言模型代理的AIoT智能家居
  • 活动邀请 | 「招商大脑 · 运营引擎」解码大数据招商与智慧园区运营新模式 / 限时报名中!
  • nginx实现同一个端口监听多个服务
  • 通过Quartus II实现Nios II编程
  • 【25软考网工】第三章(2)以太网帧结构与封装、以太网物理层标准
  • JavaScript性能优化
  • 【Linux】详细介绍进程的概念
  • Unity 将Excel表格中的数据导入到Mysql数据表中
  • C++ 中 std::queue的使用详解
  • 线程封装
  • Pytorch图像数据转为Tensor张量