HarmonyOS6 半年磨一剑 - RcInput 组件样式系统与尺寸规范深度剖析
文章目录前言一、尺寸规范体系1.1 三档尺寸设计1.2 尺寸优先级规则二、颜色体系2.1 默认颜色规范2.2 动态边框颜色计算2.3 主题色自定义示例三、边框与圆角系统3.1 圆角参数3.2 全圆角搜索框示例四、内外边距控制4.1 内边距设计4.2 外边距设计五、禁用状态的完整视觉实现总结前言一个组件好不好用样式系统的设计至关重要。它决定了组件能不能融入千变万化的业务 UI也决定了开发者修改样式时是轻松愉悦还是举步维艰。半年磨一剑打磨出的RcInput组件构建了一套从尺寸、颜色、边框到间距的完整样式体系既提供开箱即用的默认规范又保留充分的定制空间。本文将逐层拆解这套样式系统的实现逻辑让你彻底掌握如何驾驭它。一、尺寸规范体系1.1 三档尺寸设计RcInput提供small、default、large三档预设尺寸适配不同的信息密度场景尺寸值高度字体大小图标大小适用场景small32vp12vp16vp紧凑型表单、筛选栏、搜索栏default36vp14vp20vp通用表单输入large40vp16vp22vp突出强调的主要输入项三个私有方法分别负责各自维度的尺寸计算// 获取输入框高度privategetInputHeight():string|number{// 如果外部显式传入了高度优先使用外部值if(this.inputHeight!auto){returngetSizeByUnit(this.inputHeight)}switch(this.inputSize){casesmall:return32caselarge:return40casedefault:default:return36}}// 获取字体大小privategetFontSize():string|number{switch(this.inputSize){casesmall:return12caselarge:return16casedefault:default:// default 尺寸下读取 fontSize 属性支持自定义returngetSizeByUnit(this.fontSize)}}// 获取图标大小privategetIconSize():string|number{switch(this.inputSize){casesmall:return16caselarge:return22casedefault:default:// default 尺寸下读取 iconSize 属性支持自定义returngetSizeByUnit(this.iconSize)}}提示small和large尺寸的字体和图标大小是固定的规范值不受fontSize、iconSize属性影响只有default尺寸才会读取这两个属性。这保证了预设尺寸的视觉一致性。1.2 尺寸优先级规则组件高度的决策遵循外部显式 预设规格的优先级inputHeight ! auto 使用 inputHeight自定义高度最高优先级 inputHeight auto 根据 inputSize 查表获取预设高度这样设计的好处是绝大多数情况下只需设置inputSize即可特殊场景下可以用inputHeight精确控制两套机制互不干扰。完整的三档尺寸演示EntryComponentV2struct InputSizeDemo{Localval1:stringLocalval2:stringLocalval3:stringbuild(){Column({space:16}){Text(输入框尺寸演示).fontSize(20).fontWeight(FontWeight.Bold).margin({bottom:8})Text(small - 紧凑型).fontSize(12).fontColor(#909399)RcInput({value:this.val1,onValueChange:(v:string){this.val1v},inputSize:small,placeholder:小尺寸输入框 (高度 32vp)})Text(default - 标准型).fontSize(12).fontColor(#909399)RcInput({value:this.val2,onValueChange:(v:string){this.val2v},inputSize:default,placeholder:默认尺寸输入框 (高度 36vp)})Text(large - 突出型).fontSize(12).fontColor(#909399)RcInput({value:this.val3,onValueChange:(v:string){this.val3v},inputSize:large,placeholder:大尺寸输入框 (高度 40vp)})}.padding(24).width(100%).backgroundColor(#F5F7FA)}}二、颜色体系2.1 默认颜色规范RcInput预设了一套遵循 Element Plus 设计规范的默认颜色值与主流设计系统高度兼容颜色属性默认值说明inputBorderColor#DCDFE6默认边框色浅灰focusBorderColor#409EFF聚焦边框色蓝色inputBackgroundColor#FFFFFF背景色白色textColor#303133文本颜色深灰iconColor#909399图标颜色中灰占位符颜色#C0C4CC硬编码在渲染层禁用背景色#F5F7FA硬编码在渲染层禁用边框色#E4E7ED由getCurrentBorderColor()返回2.2 动态边框颜色计算边框颜色是组件状态的重要视觉反馈由getCurrentBorderColor()方法统一管理privategetCurrentBorderColor():string|Resource{// 禁用状态最高优先级使用更浅的灰色if(this.disabled){return#E4E7ED}// 聚焦状态高亮边框增强交互感if(this.isFocused){returnthis.focusBorderColor}// 默认状态标准边框颜色returnthis.inputBorderColor}三种边框状态的视觉语义默认态#DCDFE6低调的灰色不干扰内容聚焦态#409EFF可配置蓝色高亮清晰告知用户当前操作区域禁用态#E4E7ED更浅的灰色搭配opacity: 0.6视觉上明显降低光标颜色也与聚焦边框颜色保持一致形成视觉统一TextInput({text:this.innerValue,placeholder:this.placeholder}).caretColor(this.focusBorderColor)// 光标颜色与聚焦边框色联动2.3 主题色自定义示例通过修改颜色属性可以快速实现品牌主题适配EntryComponentV2struct ThemeColorDemo{Localv1:stringLocalv2:stringLocalv3:stringbuild(){Column({space:20}){Text(主题色定制演示).fontSize(20).fontWeight(FontWeight.Bold).margin({bottom:8})// 品牌蓝主题RcInput({value:this.v1,onValueChange:(v:string){this.v1v},placeholder:品牌蓝主题,focusBorderColor:#1890FF,inputBorderColor:#BAD6FF})// 品牌绿主题RcInput({value:this.v2,onValueChange:(v:string){this.v2v},placeholder:成功绿主题,focusBorderColor:#52C41A,inputBorderColor:#B7EB8F})// 警告橙主题RcInput({value:this.v3,onValueChange:(v:string){this.v3v},placeholder:警告橙主题,focusBorderColor:#FA8C16,inputBorderColor:#FFD591,iconColor:#FA8C16})}.padding(24).width(100%).backgroundColor(#F5F7FA)}}三、边框与圆角系统3.1 圆角参数inputBorderRadius接受RcStringNumber类型即数字单位 vp或带单位的字符串ParaminputBorderRadius:RcStringNumber4在渲染层通过getSizeByUnit()工具函数统一处理单位转换Row(){/* 输入框容器 */}.borderRadius(getSizeByUnit(this.inputBorderRadius)).border({width:1,color:this.getCurrentBorderColor(),style:BorderStyle.Solid})常见圆角风格对照圆角值视觉风格适用场景4微圆角默认通用表单8中等圆角卡片式设计20大圆角搜索框、聊天输入999药丸形标签搜索、特殊强调3.2 全圆角搜索框示例EntryComponentV2struct RoundInputDemo{LocalsearchText:stringbuild(){Column({space:16}){Text(圆角风格演示).fontSize(20).fontWeight(FontWeight.Bold).margin({bottom:8})RcInput({value:this.searchText,onValueChange:(v:string){this.searchTextv},placeholder:搜索,prefixIcon:icon-houi_search_outline,clearable:true,inputBorderRadius:20,focusBorderColor:#409EFF,rcPadding:{left:16,right:16}})}.padding(24).width(100%).backgroundColor(#F5F7FA)}}四、内外边距控制4.1 内边距设计rcPadding控制输入框容器的内边距默认值为左右各 12vpParamrcPadding:Padding|Length{left:12,right:12}注意默认值只设置了水平方向的内边距垂直方向交由高度属性inputHeight/inputSize自然撑开避免内容被额外压缩。常见内边距配置// 宽松型适合大尺寸输入框rcPadding:{left:16,right:16}// 紧凑型适合小尺寸、空间有限场景rcPadding:{left:8,right:8}// 全方向自定义高度时使用rcPadding:{left:12,right:12,top:10,bottom:10}4.2 外边距设计rcMargin控制组件整体的外边距通常用于调整输入框在布局中的间距ParamrcMargin:Padding|Length0结合Column的space属性大多数时候不需要单独设置rcMargin仅在需要精细控制某个输入框间距时使用。五、禁用状态的完整视觉实现禁用状态的视觉反馈由多个属性协同实现Row(){/* 输入框容器 */}.backgroundColor(this.disabled?#F5F7FA:this.inputBackgroundColor)// 背景变灰.opacity(this.disabled?0.6:1)// 整体透明度降低.border({width:1,color:this.getCurrentBorderColor(),// 边框颜色变浅style:BorderStyle.Solid})TextInput().enabled(!this.disabled!this.readonly)// 底层输入框禁用交互四个维度共同构成禁用状态背景色变为#F5F7FA浅灰整体透明度降至0.6边框色变为#E4E7ED更浅的灰TextInput.enabled(false)禁止用户交互完整禁用与只读对比演示EntryComponentV2struct DisabledReadonlyDemo{build(){Column({space:16}){Text(状态演示).fontSize(20).fontWeight(FontWeight.Bold).margin({bottom:8})Text(正常状态).fontSize(12).fontColor(#909399)RcInput({value:可以正常编辑,onValueChange:(){},placeholder:正常状态})Text(禁用状态).fontSize(12).fontColor(#909399)RcInput({value:禁用后无法编辑,disabled:true,placeholder:禁用状态})Text(只读状态).fontSize(12).fontColor(#909399)RcInput({value:只读内容不可修改,readonly:true,placeholder:只读状态})}.padding(24).width(100%).backgroundColor(#F5F7FA)}}提示disabled和readonly的区别disabled有完整的禁用视觉透明度 灰背景而readonly仅禁止编辑视觉上与正常输入框一致通常用于展示不可修改的信息。总结RcInput的样式系统以预设优先、自定义兜底为核心理念三档尺寸规范、语义化颜色体系、动态边框状态让组件开箱即用而inputHeight、fontSize、颜色系列属性、rcPadding等精细化参数又确保了任何特殊场景下的定制空间。掌握这套样式体系即可在HarmonyOS6应用开发中游刃有余地构建视觉一致、品牌感强的输入交互界面。如果这篇文章对你有帮助欢迎点赞、收藏、关注你的支持是我持续创作的动力
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2442196.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!