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改版时的维护成本。
相关推荐
七夜zippoe3 天前
API设计规范:RESTful API设计与OpenAPI(Swagger)完整指南
后端·restful·设计规范
zh_xuan3 天前
Android compose 可见性动画未执行问题修复
android·compose
hnlgzb4 天前
请详细解释一下MVVM这个设计模型
android·kotlin·android jetpack·compose
yinghuoAI20264 天前
电商视觉进入“无人区”:萤火AI如何用三把“手术刀”重构设计 workflow
设计模式·新媒体运营·产品运营·流量运营·用户运营·内容运营·设计规范
hnlgzb6 天前
目前编写安卓app的话有哪几种设计模式?
android·设计模式·kotlin·android jetpack·compose
zh_xuan9 天前
Android compose Navigation 页面导航
android·compose
电子科技圈10 天前
SmartDV展示汽车IP解决方案以赋能智驾创芯并加速规模化普及
嵌入式硬件·设计模式·硬件架构·软件工程·软件构建·设计规范
stevenzqzq12 天前
Kotlin 进阶指南:中缀函数 (Infix Function)
android·kotlin·compose
xiangw@GZ14 天前
CapSense底层逻辑:硬件设计规范
单片机·嵌入式硬件·设计规范
zh_xuan17 天前
Android compose 自定义主题
android·compose