当前位置: 首页 > article >正文

鸿蒙PC开发的Slider组件blockSize参数的类型要求

踩坑记录06Slider组件blockSize参数的类型要求阅读时长7分钟 |难度等级初级 |适用版本HarmonyOS NEXT (API 12)关键词Slider、blockSize、SizeOptions、原生组件声明本文基于真实项目开发经历编写所有代码片段均来自实际踩坑场景。欢迎加入开源鸿蒙PC社区https://harmonypc.csdn.net/项目 Git 仓库https://atomgit.com/Dgr111-space/HarmonyOS 前言导读在 HarmonyOS 的 ArkTS 开发中踩坑记录06Slider 组件 blockSize 参数的类型要求 是很多新手都会遇到的问题。本文记录了完整的踩坑经历——从错误复现到根因定位再到解决方案希望能帮助你在遇到类似问题时快速定位方向。踩坑记录06Slider 组件 blockSize 参数的类型要求严重程度⭐⭐ |发生频率中涉及模块原生 Slider 组件、SizeOptions 类型一、问题现象Type 16 has no properties in common with type SizeOptions.给 Slider 组件的滑块设置大小时传一个简单的数字竟然被编译器拒绝。二、错误代码// HSlider.ets - 编译失败Slider({value:this.sliderValue,min:0,max:100,style:SliderStyle.InSet}).blockSize(16)// ❌ Error: 数字类型不兼容三、根因分析ArkTS 原生Slider.blockSize()方法的签名要求SizeOptions类型// ArkTS 框架定义interfaceSizeOptions{width:number|stringheight:number|string}// Slider APIblockSize(size:SizeOptions):SliderAttribute设计原因滑块通常是圆形的需要同时指定宽和高框架强制使用对象确保完整性。四、解决方案// ✅ 正确写法.blockSize({width:18,height:18})// ✅ 非正方形滑块罕见.blockSize({width:20,height:12})// ✅ 使用 vp 单位.blockSize({width:18vp,height:18vp})五、完整的 HSlider 重构import{ThemeColors}from./theme/typesComponentexportstruct HSlider{PropsliderValue:number0PropminVal:number0PropmaxVal:number100PropstepVal:number1PropisDisabled:booleanfalseonSliderChange?:(value:number)voidprivategetColors():ThemeColors{returnAppStorage.getThemeColors(themeColors)??newThemeColors()}build(){Row({space:12}).width(100%).alignItems(VerticalAlign.Center).height(40).padding({left:4,right:4}){// 原生 Slider 组件Slider({value:this.sliderValue,min:this.minVal,max:this.maxVal,step:this.stepVal,style:SliderStyle.InSet}).layoutWeight(1).blockColor(this.getColors().primary).trackColor(this.getColors().borderLight).selectedColor(this.getColors().primary).trackThickness(6).blockSize({width:18,height:18})// ✅ SizeOptions 格式.enabled(!this.isDisabled).onChange((value){if(this.onSliderChange)this.onSliderChange(value)})Text(${Math.round(this.sliderValue)}).fontSize(13).fontColor(this.getColors().textPrimary).width(36).textAlign(TextAlign.End)}}}六、Slider 样式对照渲染错误:Mermaid 渲染失败: Parse error on line 4: ... A[OutSet] -- [滑块在轨道外部传统样式] -----------------------^ Expecting AMP, COLON, PIPE, TESTSTR, DOWN, DEFAULT, NUM, COMMA, NODE_STRING, BRKT, MINUS, MULT, UNICODE_TEXT, got SQS属性OutSetInSet推荐SetIn视觉效果滑块浮于轨道上方滑块嵌入轨道特殊内嵌适用场景传统控件现代 UI 设计特殊需求推荐值—本项目采用—七、经验总结不要假设 API 签名即使是看起来应该接受数字的参数也可能需要特定类型自定义组件封装的价值将原生组件包装为业务组件后这类细节问题只需解决一次保持组件库一致性整个项目的 Slider 都走 HSlider 封装层修改一处全局生效参考资源与延伸阅读官方文档HarmonyOS ArkTS 语言参考ArkUI 组件参考系列导航本文是「HarmonyOS 开发踩坑记录」系列的第 06 篇。该系列共 30 篇涵盖 ArkTS 语法、组件开发、状态管理、网络请求、数据库、多端适配等全方位实战经验。工具与资源### 工具与资源DevEco Studio 官方下载 — HarmonyOS 官方IDEHarmonyOS 开发者社区 — 技术问答与经验分享 如果这篇对你有帮助欢迎点赞、收藏、评论你的支持是我持续输出高质量技术内容的动力

相关文章:

鸿蒙PC开发的Slider组件blockSize参数的类型要求

踩坑记录06:Slider组件blockSize参数的类型要求 阅读时长:7分钟 | 难度等级:初级 | 适用版本:HarmonyOS NEXT (API 12) 关键词:Slider、blockSize、SizeOptions、原生组件 声明:本文基于真实项目开发经历编…...

传统微波IDU与数字IP微波ODU扩展单元(数字微波IDU)技术对比分析

随着半导体技术的飞速迭代,数字微波通信设备的设计架构实现了从分体式到全室外集成式的跨越式发展,核心组件的功能定位与应用场景也随之发生深刻变革。早期传统数字微波ODU(室外单元)采用IDU(室内单元)与OD…...

地平线首款舱驾融合芯片即将量产;速腾聚创发布创世架构推出双旗舰感知芯片;多项固态电池技术重大突破;蔡司研发全息透明显示技术

地平线首款舱驾融合芯片即将量产牛喀网获悉,地平线发布中国首款舱驾融合整车智能体芯片星空Starry,该芯片采用5nm车规制程,BPU算力达650TOPS,内存带宽273GB/s,集成20核CPU。其采用统一内存架构与城堡安全物理隔离架构&…...

别再只会写required了!Element UI Form表单rules的10个高级玩法(含自定义校验函数)

解锁Element UI表单校验的隐藏能力:10个高阶规则实战指南 在Vue生态中,Element UI凭借其优雅的表单组件成为中后台开发的首选。但大多数开发者仅仅停留在required: true的基础校验层面,实际上其基于async-validator的校验系统蕴藏着令人惊喜的…...

YOLO11涨点优化:Block优化 | 结合FasterNet核心PConv (Partial Convolution),大幅削减浮点运算,FPS直线飙升

一、引言:当FLOPs不再是唯一答案——轻量化部署的困局 计算机视觉领域,目标检测模型正在经历一场从“精度为王”到“效率为王”的深刻转型。根据Ultralytics官方博客介绍,YOLO11通过增强特征提取功能和更高效的架构设计,在实时物体检测、实例分割和姿态估计等多个任务上都…...

创新技术学习:如何快速掌握一个全新的技术领域

创新技术学习:如何快速掌握一个全新的技术领域 在技术飞速发展的今天,掌握新技能已成为职业发展的关键。无论是人工智能、区块链,还是云计算,快速学习新技术的能力决定了个人和企业的竞争力。面对庞杂的知识体系,许多…...

从“主动错误”到“总线关闭”:深入理解CAN节点错误状态机与计数器(TEC/REC)

从“主动错误”到“总线关闭”:深入理解CAN节点错误状态机与计数器(TEC/REC) 在汽车电子和工业控制领域,CAN总线作为经典的现场总线协议,其可靠性直接影响着整个系统的稳定性。当某个CAN节点开始频繁发送错误帧时&…...

手把手教你用Modelsim仿真验证FPGA的PLL输出:从代码到波形图的全流程避坑

FPGA设计中PLL仿真验证全攻略:从Testbench编写到波形分析实战 在FPGA开发中,锁相环(PLL)作为时钟管理的核心组件,其稳定性直接影响整个系统的可靠性。但很多工程师在完成PLL代码编写后,常常面临一个关键问题:如何确认P…...

汽车网络通讯分析与仿真工具的系统工程:Vector CANoe与ZLG ZCANPRO深度剖析

目录 摘要 第一部分:软件架构设计与仿真引擎开发 事件驱动型仿真引擎与实时调度 CAPL 编程语言 ZCANPRO 的软件架构 第二部分:硬件架构与高精度总线接口开发 基于 FPGA 的通讯控制器设计 MCU 架构与工业级稳定性 硬件同步与时间基准 第三部分&…...

Windows 11 窗口美化终极指南:让所有应用焕发 Mica 质感

Windows 11 窗口美化终极指南:让所有应用焕发 Mica 质感 【免费下载链接】MicaForEveryone Mica For Everyone is a tool to enable backdrop effects on the title bars of Win32 apps on Windows 11. 项目地址: https://gitcode.com/gh_mirrors/mi/MicaForEvery…...

零代码RPA神器taskt:如何用免费开源工具实现跨平台自动化革命

零代码RPA神器taskt:如何用免费开源工具实现跨平台自动化革命 【免费下载链接】taskt taskt (pronounced tasked and formely sharpRPA) is free and open-source robotic process automation (rpa) built in C# powered by the .NET Framework 项目地址: https:/…...

从零开始玩转Arduino:开源开发工具带你轻松进入硬件世界

从零开始玩转Arduino:开源开发工具带你轻松进入硬件世界 【免费下载链接】Arduino Arduino IDE 1.x 项目地址: https://gitcode.com/gh_mirrors/ar/Arduino 想象一下,你有一个创意想法,想要让LED灯随着音乐节奏闪烁,或者制…...

WinUtil:3步搞定Windows系统优化的终极解决方案

WinUtil:3步搞定Windows系统优化的终极解决方案 【免费下载链接】winutil Chris Titus Techs Windows Utility - Install Programs, Tweaks, Fixes, and Updates 项目地址: https://gitcode.com/GitHub_Trending/wi/winutil WinUtil是一款功能强大的Windows系…...

DDrawCompat:让经典DirectX游戏在现代Windows系统上重获新生

DDrawCompat:让经典DirectX游戏在现代Windows系统上重获新生 【免费下载链接】DDrawCompat DirectDraw and Direct3D 1-7 compatibility, performance and visual enhancements for Windows Vista, 7, 8, 10 and 11 项目地址: https://gitcode.com/gh_mirrors/dd/…...

运算放大器(二):恒流源电路的设计与负载适应性分析

1. 运算放大器恒流源的基本原理 我第一次接触恒流源电路是在调试LED灯板的时候。当时发现直接用电阻限流,亮度会随着电源电压波动而变化,这才意识到恒流源的重要性。简单来说,恒流源就像个"智能水龙头",不管水管&#x…...

B站评论区身份标签智能识别:从信息过载到精准互动的技术实践

B站评论区身份标签智能识别:从信息过载到精准互动的技术实践 【免费下载链接】bilibili-comment-checker B站评论区自动标注成分,支持动态和关注识别以及手动输入 UID 识别 项目地址: https://gitcode.com/gh_mirrors/bil/bilibili-comment-checker …...

Avalonia v11跨平台实战:从安装到多平台项目部署

1. Avalonia v11初体验:为什么选择这个跨平台UI框架? 第一次接触Avalonia是在去年一个需要同时支持Windows和macOS的项目中。当时尝试过几种跨平台方案,要么性能堪忧,要么开发体验差强人意。直到同事推荐了Avalonia,用…...

5分钟掌握ncmdump:网易云音乐NCM格式一键解密终极指南 [特殊字符]

5分钟掌握ncmdump:网易云音乐NCM格式一键解密终极指南 🎵 【免费下载链接】ncmdump 项目地址: https://gitcode.com/gh_mirrors/ncmd/ncmdump 你是否曾经遇到过这样的烦恼?辛辛苦苦在网易云音乐下载的歌曲,换了个播放器就…...

从B站视频到实操:StaMPS-PSI处理中的那些“坑”与高效调试技巧(基于Gamma和mt_prep_gamma)

从B站视频到实操:StaMPS-PSI处理中的那些“坑”与高效调试技巧 在B站等平台学习StaMPS-PSI处理的过程中,许多初学者会经历从“一看就会”到“一做就废”的典型困境。尼莫大佬等UP主的教程视频虽然详细展示了操作流程,但当用户真正动手复现时&…...

【源码深度】Android 架构设计+组件化+模块化+插件化|面试终章 第29讲

...

告别片上串口不够用:手把手教你用STM8S003F3P6的IO口模拟串口实现双机通信

突破硬件限制:STM8S003F3P6 IO模拟串口实现双机通信实战指南 在嵌入式开发中,STM8S003F3P6因其高性价比成为许多低成本项目的首选。然而这款芯片仅有一个硬件UART接口,当项目需要同时连接多个串口设备时,开发者往往陷入资源不足的…...

保姆级教程:用Termux在安卓手机上装Kali Linux(附VNC桌面配置与常见网络问题解决)

安卓手机零基础部署Kali Linux实战指南:从Termux配置到VNC远程桌面 在移动互联网时代,安全研究人员和开发者常常需要在不同场景下快速搭建渗透测试环境。本文将手把手教你如何在不Root安卓设备的情况下,通过Termux终端模拟器完整部署Kali Lin…...

PTA天梯赛L1-006连续因子:从质数到合数的边界处理,一个易错点差点让我丢分

PTA天梯赛L1-006连续因子:从质数陷阱到边界条件的深度剖析 那天深夜,当我第17次提交L1-006题解时,屏幕上刺眼的"Wrong Answer"让我彻底清醒——60这个看似简单的测试用例,竟然让我的算法输出了错误的234而非正确的345。…...

从 ArrayList 到 LinkedList:深入源码,图解 Java subList 的‘视图’魔法与性能影响

从 ArrayList 到 LinkedList:深入源码,图解 Java subList 的‘视图’魔法与性能影响 当你需要在 Java 中处理列表的部分数据时,subList 方法提供了一种看似简单却暗藏玄机的解决方案。不同于创建一个全新的列表副本,subList 生成的…...

Windows多显示器DPI独立控制:绕过系统限制的底层API实践

Windows多显示器DPI独立控制:绕过系统限制的底层API实践 【免费下载链接】SetDPI 项目地址: https://gitcode.com/gh_mirrors/se/SetDPI 在Windows多显示器工作环境中,不同分辨率的显示器需要独立的DPI缩放设置,但系统界面却将这一功…...

从Modbus到蓝牙:深入浅出图解CRC-16 CCITT的位反序到底在干什么

从Modbus到蓝牙:深入浅出图解CRC-16 CCITT的位反序到底在干什么 当你第一次在Modbus协议文档中看到"CRC-16 CCITT"这个术语时,可能会觉得它只是众多校验算法中的普通一员。但当你真正开始实现它,特别是在处理"位反序"这个…...

别再重装环境了!手把手教你迁移Python虚拟环境(解决Fatal error in launcher报错)

Python虚拟环境迁移实战:彻底解决路径依赖与Fatal error报错 每次接手同事的Python项目或从GitHub克隆代码时,最让人头疼的莫过于那个精心配置却无法正常激活的虚拟环境。特别是当看到Fatal error in launcher: Unable to create process using...这样的…...

告别重启烦恼:手把手教你用UEFI Capsule Update实现Windows/Linux系统固件无感升级

告别重启烦恼:手把手教你用UEFI Capsule Update实现Windows/Linux系统固件无感升级 每次固件更新都要重启系统?运维工程师们早已厌倦了这种打断业务连续性的操作。UEFI Capsule Update技术正在改变这一现状——它允许你在操作系统运行时完成固件更新&…...

TrollInstallerX:iOS 14.0-16.6.1设备如何一键部署TrollStore?

TrollInstallerX:iOS 14.0-16.6.1设备如何一键部署TrollStore? 【免费下载链接】TrollInstallerX A TrollStore installer for iOS 14.0 - 16.6.1 项目地址: https://gitcode.com/gh_mirrors/tr/TrollInstallerX 对于iOS开发者和技术爱好者而言&a…...

别再拍脑袋做决定了!用Excel手把手教你搞定AHP层次分析法(附一致性检验避坑指南)

Excel实战:用AHP层次分析法科学决策(附一致性检验全流程) 决策是职场中最常见的挑战之一——从供应商筛选到项目优先级排序,从人才评估到个人职业规划,我们总在多个选项中反复权衡。传统拍脑袋决策方式往往导致"选…...