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改版时的维护成本。
相关推荐
stevenzqzq4 小时前
Compose 三层结构设计规范1(基于Slot API)
设计规范·compose
bug攻城狮1 天前
SpringBoot 脚手架搭建指南:从零构建企业级开发框架
java·spring boot·后端·架构·系统架构·设计规范
Watermelo6172 天前
【前端实战】构建 Vue 全局错误处理体系,实现业务与错误的清晰解耦
前端·javascript·vue.js·信息可视化·性能优化·前端框架·设计规范
KANGBboy2 天前
埋点设计规范
设计规范
小湘西3 天前
图的分类大全
设计规范
九硕智慧建筑一体化厂家4 天前
DDC:看似普通的存在,在楼宇自控系统中却主宰智能建筑高效运行?
大数据·运维·人工智能·网络协议·制造·设计规范
天天睡大觉4 天前
SH/T 3009-2013 石油化工可燃性气体排放系统设计规范
设计规范·sh∕t 3009-2013·可燃性气体排放系统设计规范
电子科技圈6 天前
从工具到平台:如何化解跨架构时代的工程开发和管理难题
人工智能·设计模式·架构·编辑器·软件工程·软件构建·设计规范
xu_wenming6 天前
跨文件数据共享模式:通过静态全局变量与访问函数结合
嵌入式硬件·mcu·物联网·设计规范