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

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>
);

优势

  • 动态生成能力:可以通过修改配置文件快速调整页面内容。

相关文章:

  • UIAutomator 与 Playwright 在 AI 自动化中的界面修改对比
  • IP-guard离线卸载客户端及清除策略说明
  • 基于Python Socket的多线程聊天程序实现
  • pod内部共享命名空间与k8s命名空间是一个东西吗?
  • Podman Desktop:现代轻量容器管理利器(Podman与Docker)
  • Vmware安装centos7和Redis
  • kafka安装、spark安装
  • 概率dp总结
  • LangChain Runnable简介
  • 黑马点评redis改 part 5
  • C++ STL 容器简介(蓝桥杯适用精简版)
  • docker底层原理简述
  • 开源版「v0」OpenUI:根据文本生成UI界面代码
  • 读书笔记:淘宝十年产品与技术演进史
  • 配置Spark历史服务器,轻松查看任务记录
  • 算法训练营第一天|704.二分查找、27.移除元素、977.有序数组的平方
  • 【哈希表】1399. 统计最大组的数目
  • Java学习手册:Web 安全基础
  • 【KWDB 创作者计划】_上位机知识篇---MicroPython
  • 青少年编程与数学 02-018 C++数据结构与算法 06课题、树
  • 因雷雨、沙尘等天气,这些机场航班运行可能受影响
  • 图忆|上海车展40年:中国人的梦中情车有哪些变化(上)
  • 证监会:坚决拥护党中央对王建军进行纪律审查和监察调查决定
  • 全国台联原会长杨国庆逝世,享年89岁
  • 两部门调度部署“五一”假期安全防范工作,要求抓好旅游安全
  • “80后”商洛市委副书记、市政府党组副书记赵孝任商洛市副市长