谈谈 React 组件设计原则笔记
从易用性、可维护性、可复用性三个方面考虑
- 易用性:从组件使用者角度出发
- 规范的 API:通用命名、尽量提供默认值
- 支持组件组装
- 支持 renderProps 和 ReactNode props
- 尽可能受控,某些场景也暴露非受控方式
- 可维护性:从组件维护者角度出发
- 可以从 solid 角度考虑
- 组合优于继承
- 可复用性:同时从组件使用者和维护者角度出发
- 样式覆盖
- 梳理并提供可能存在需求的 slot :比如选择器组件的 renderFooter
- Headless UI :两个模式,以 hooks 方式复用逻辑并保留不复用 UI、提供原子组件
# 规范的 API
减少必填项,提供默认值
通用命名原则:
- onXXX:监听/触发方法
- renderXXX:含参的渲染方法,比如
renderItem: (data) => Element
; 无参推荐直接传 Element ,比如 title。详见:slot 和 renderProps 的选择 - beforeXXX/afterXXX:前置/后置动作,比如 beforeUpload/afterUpload
- xxxProps:组件中的子组件属性命名,比如
- 优先使用常见单词进行命名,如:value、visible、size、disabled、label、type 等等
- 暴露通用参数:style、className、rootClassName(组件最外层 className)
# slot 和 renderProps 的选择
# 拓展阅读
编辑 (opens new window)
上次更新: 2023/08/23, 09:32:05