Compose 调用层参数设计规范(基于默认值复用原则)

Compose 调用层参数设计规范(基于默认值复用原则)

一、核心设计思想

如果一个属性在大多数情况下都不变,就不应该在每个页面都去设置它。

  • 调用层(Page/Screen)职责:仅填充业务内容,不配置UI细节。
  • 中间层职责:完成通用UI配置后,调用层应"保持沉默",仅传递差异化数据。

通俗类比:订购笔记本电脑

层级 角色 核心行为
结构层 工厂模具 定义屏幕位置、键盘位置等基础布局规则
中间层 产品经理 定义默认银色、默认16G内存、默认带充电器等通用配置
调用层 消费者 场景A(标准版):仅说"我要一台"(无差异化数据);场景B(定制版):仅说"我要32G内存"(仅传差异化数据)

二、代码写法对比

前提

UserInfoCard 中间层已配置默认背景、默认图标、默认样式。

1. 坏的写法(未利用默认值)

调用层重复传递通用UI配置,代码臃肿且难以维护:

kotlin 复制代码
// 调用层
UserInfoCard(
    title = "陈奕迅",
    backgroundImage = R.drawable.ic_mine_login, // 每次都要传
    titleRightDrawable = IconRes(R.drawable.svg_tag_vip), // 每次都要传
    bottomRightDrawable = IconRes(R.drawable.svg_arrow), // 每次都要传
    padding = 16.dp // 甚至还要传间距
)
2. 好的写法(仅传差异化数据)

场景A:最基础的展示(仅传核心业务数据)

kotlin 复制代码
// 只需要传 title,因为除了 title,别的卡片都长一样
UserInfoCard(title = "陈奕迅") 

场景B:超级VIP用户(仅传差异化图标)

kotlin 复制代码
// 只有"图标"是和别人不一样的(差异化),所以只传图标
UserInfoCard(
    title = "周杰伦",
    titleRightDrawable = IconRes(R.drawable.svg_tag_super_vip) 
)

三、核心优势

  1. 代码可读性:调用层可直接体现卡片的业务重点(如"该卡片的特殊之处是超级VIP图标")。
  2. 降低改版成本:若需修改通用配置(如所有卡片默认背景图),仅需修改中间层一个默认值,全App所有调用处自动生效;若调用层重复传参,则需修改所有调用位置。

总结

  1. 调用层应遵循"最小传参原则",仅传递与默认配置不同的差异化数据。
  2. 通用UI配置(背景、图标、间距等)统一在中间层通过默认参数定义,避免调用层重复配置。
  3. 该设计可提升代码可读性,大幅降低UI改版时的维护成本。
相关推荐
薛定猫AI1 天前
【深度解析】Claude Code Skills 工作流:用知识图谱、设计规范与 Agent 工具链提升 AI 编程效率
人工智能·知识图谱·设计规范
cui17875683 天前
排队免单模式:从爆火到优化,探寻实体商业新出路
大数据·人工智能·设计模式·个人开发·设计规范
电子科技圈6 天前
IAR作为Qt Group独立BU携两项重磅汽车电子应用开发方案首秀北京车展
开发语言·人工智能·汽车·软件工程·软件构建·代码规范·设计规范
儿歌八万首6 天前
Compose 自定义组件:封装一个通用标题栏
android·compose·标题栏
xiaohuoji1296 天前
量化交易系统架构设计:从回测到实盘的4层分层方案(附架构图)
大数据·人工智能·数据挖掘·数据分析·个人开发·设计规范
stevenzqzq9 天前
Android Compose LaunchedEffect 异步执行机制深度解析
compose
stevenzqzq11 天前
使用 derivedStateOf 优化高频状态下的 UI 重组
compose
安卓程序员_谢伟光11 天前
m3颜色定义
android·compose
stevenzqzq11 天前
Compose 性能优化利器:derivedStateOf 核心详解
compose
BitaHub202411 天前
AI 也能按设计规范出图?Qwen-Image-2512 本地海报生成实战
人工智能·设计规范·bitahub