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

HarmonyOS6 Tabs 组件完全指南:从零上手底部导航

文章目录一、Tabs 组件是什么二、核心结构三、基础接口说明四、基础用法示例4.1 最简单的底部标签栏4.2 带系统图标的标签栏4.3 完全自定义标签推荐方式五、重要属性一览5.1 barMode — 标签栏排列模式5.2 scrollable — 是否允许手势滑动切换5.3 animationDuration — 切换动画时长5.4 barHeight — 标签栏高度六、onChange — 监听切换事件七、隐藏系统标签栏完全自定义场景八、常见问题总结一、Tabs 组件是什么Tabs 是 HarmonyOS ArkUI 框架内置的标签页导航组件几乎所有主流应用的底部导航栏都由它来承载。它把多个内容页面叠放在一起通过点击顶部或底部的标签按钮来切换视图。生活中有一个非常直观的类比就像一本有分隔页的活页笔记本每个分隔页标有不同的分类名称。Tabs 组件就是这本笔记本在应用里的数字形态。二、核心结构Tabs 组件由两部分协作完成导航TabBar标签导航栏可出现在顶部、底部或侧边。TabContent内容区是 Tabs 的唯一合法直接子组件每个TabContent对应一个标签页面。三、基础接口说明// Tabs 构造参数Tabs({barPosition?:BarPosition,// 标签栏位置Start顶部或 End底部index?:number,// 初始选中索引默认 0controller?:TabsController// 编程控制器可在代码中主动切换标签})barPosition与vertical属性组合决定标签栏最终出现的位置verticalbarPosition.StartbarPosition.Endfalse默认横向标签在顶部标签在底部true纵向标签在左侧标签在右侧四、基础用法示例4.1 最简单的底部标签栏EntryComponentstruct BasicTabsDemo{build(){// barPosition.End 将标签栏放在屏幕底部Tabs({barPosition:BarPosition.End}){TabContent(){Text(首页内容)}.tabBar(首页)// 字符串形式设置标签文字TabContent(){Text(分类内容)}.tabBar(分类)TabContent(){Text(我的内容)}.tabBar(我的)}}}代码说明barPosition: BarPosition.End让标签栏出现在底部.tabBar(文字)是最简单的标签设置方式系统会渲染默认样式每个TabContent内部可以放任意组件包括List、Grid、Scroll等。4.2 带系统图标的标签栏TabContent(){Text(首页内容)}.tabBar({icon:$r(sys.symbol.house),// 未选中时显示的图标activeIcon:$r(sys.symbol.house_fill),// 选中时显示的图标text:首页})代码说明$r(sys.symbol.house)引用 HarmonyOS 内置的 Symbol 图标不需要导入额外图片资源sys.symbol.xxx_fill是填充版图标视觉上更突出适合选中状态。4.3 完全自定义标签推荐方式在本项目的RegularTabsDemo.ets中自定义标签栏的核心实现如下// 标签数据由 TabItem 接口统一管理Statetabs:TabItem[][];// 在 aboutToAppear 中初始化数据aboutToAppear(){this.tabs[{id:home,icon:$r(sys.symbol.house),activeIcon:$r(sys.symbol.house_fill),title:首页,},{id:cart,icon:$r(sys.symbol.cart),activeIcon:$r(sys.symbol.cart_fill),title:购物车,badge:3,// 角标数量},// ...];}// 自定义 TabBar UIRow(){ForEach(this.tabs,(tab:TabItem,index:number){Column(){// 根据 currentIndex 切换图标和颜色SymbolGlyph(this.currentIndexindex?tab.activeIcon:tab.icon).fontSize(24).fontColor(this.currentIndexindex?[#007AFF]:[#8E8E93])Text(tab.title).fontSize(11).fontColor(this.currentIndexindex?#007AFF:#8E8E93).margin({top:2})}.width(60).height(56).justifyContent(FlexAlign.Center).onClick((){this.currentIndexindex;// 点击时更新状态})})}代码说明State currentIndex作为选中状态的唯一数据源它变化时 UI 自动刷新SymbolGlyph的.fontColor()接受的是ResourceColor[]数组所以要写成[#007AFF]而非直接写字符串ForEach遍历tabs数组动态生成每一个标签项增减标签只需修改数据UI 自动跟随变化。五、重要属性一览5.1 barMode — 标签栏排列模式Tabs().barMode(BarMode.Fixed)// 固定标签等宽平铺适合 3-5 个标签Tabs().barMode(BarMode.Scrollable)// 可滚动标签可横向滑动适合 5 个以上5.2 scrollable — 是否允许手势滑动切换Tabs().scrollable(true)// 允许左右滑动切换内容默认开启Tabs().scrollable(false)// 禁止滑动只能点击标签切换注意如果你实现了完全自定义的 TabBar通常需要把scrollable设为false避免手势滑动与自定义逻辑冲突。5.3 animationDuration — 切换动画时长Tabs().animationDuration(300)// 切换页面时的动画时长单位毫秒Tabs().animationDuration(0)// 设为 0 则关闭切换动画5.4 barHeight — 标签栏高度Tabs().barHeight(60)// 标签栏高度单位 vp.barWidth(80%)// 纵向标签栏时有效控制侧边栏宽度六、onChange — 监听切换事件Tabs().onChange((index:number){// index 是用户切换后的目标标签索引this.currentIndexindex;console.log(当前标签:${index});})代码说明不管是用户点击还是手势滑动切换完成后都会触发onChange如果使用了TabsController.changeIndex()主动切换onChange同样会被触发要注意避免循环调用。七、隐藏系统标签栏完全自定义场景当需要实现浮动标签栏、舵式标签栏等自定义外观时需要先把系统默认的 TabBar 隐藏掉Tabs({barPosition:BarPosition.End,index:this.currentIndex}){ForEach(this.tabs,(tab:TabItem){TabContent(){// 内容页面}// 注意不调用 .tabBar()或者配合 .barHeight(0) 隐藏})}.barHeight(0)// 将系统 TabBar 高度设为 0视觉上完全隐藏.barOverlap(false)// 不让 TabBar 与内容重叠然后在外层单独绘制自定义的 TabBar 组件。八、常见问题Q1TabContent 里可以放 List 吗可以放任意组件TabContent(){List(){ListItem(){Text(项目1)}ListItem(){Text(项目2)}}}.tabBar(列表)Q2如何避让系统底部导航条// 在自定义 TabBar 上添加此属性自动扩展至安全区域Row().expandSafeArea([SafeAreaType.SYSTEM],[SafeAreaEdge.BOTTOM])Q3如何在代码中跳转到指定标签使用TabsController见下一篇文章的详细讲解。总结Tabs 组件是 HarmonyOS 应用里使用频率最高的导航结构之一入门门槛并不高。掌握barPosition、barMode、onChange这几个核心属性就能应对绝大多数日常场景。当系统默认样式满足不了设计需求时把barHeight设为 0 再自己绘制 TabBar能拿到完整的 UI 控制权。真正有意思的部分恰恰从自定义开始——接下来几篇文章会带你一步步把这件事做得更漂亮。

相关文章:

HarmonyOS6 Tabs 组件完全指南:从零上手底部导航

文章目录一、Tabs 组件是什么?二、核心结构三、基础接口说明四、基础用法示例4.1 最简单的底部标签栏4.2 带系统图标的标签栏4.3 完全自定义标签(推荐方式)五、重要属性一览5.1 barMode — 标签栏排列模式5.2 scrollable — 是否允许手势滑动…...

避开这些坑!ESP-IDF UART驱动配置详解:从menuconfig参数到ISR内存安全

ESP-IDF UART驱动深度调优指南:避开内存泄漏与中断冲突的实战技巧 在物联网设备开发中,UART通信的稳定性往往决定着整个系统的可靠性。当ESP32以115200bps的波特率持续传输数据时,一个配置不当的缓冲区可能导致每秒钟丢失多达20%的数据包。这…...

别再死记硬背了!用PyTorch手把手复现Faster R-CNN,搞懂RPN和RoI Pooling到底怎么用

从零实现Faster R-CNN:代码级解析RPN与RoI Pooling核心机制 在计算机视觉领域,目标检测一直是极具挑战性的任务。传统方法依赖手工设计特征,而深度学习时代的目标检测算法则通过端到端训练实现了质的飞跃。Faster R-CNN作为两阶段检测器的经典…...

【工业级Docker部署黄金法则】:27个真实产线案例验证的容器化落地避坑指南

第一章:工业级Docker部署黄金法则总览在生产环境中,Docker 不仅是容器化工具,更是基础设施可靠性的基石。工业级部署拒绝“能跑就行”的思维,强调可重复性、可观测性、安全隔离与生命周期可控性。以下核心法则构成高可用 Docker 实…...

销售智能体:小红书与抖音评论区自动抓取引导加微信及智能聊单系统

销售智能体:小红书与抖音评论区自动抓取引导加微信及智能聊单系统 一、系统概述与设计目标 1.1 业务背景与痛点分析 在2026年的社交媒体营销环境中,小红书已拥有超过4亿月活用户,其独特的“种草”文化和强大的搜索电商属性使其成为品牌营销和个人IP打造的必争之地。抖音同…...

深入FM33FR0xx的GPIO高级功能:用FL库实现外部中断与低功耗唤醒

深入FM33FR0xx的GPIO高级功能:用FL库实现外部中断与低功耗唤醒 在嵌入式系统设计中,GPIO(通用输入输出)接口的功能远不止简单的电平控制。对于复旦微FM33FR0xx系列MCU而言,其GPIO模块集成了外部中断触发和低功耗唤醒两…...

python argon2

## 关于 Python 中的 Argon2:一个密码哈希的现代选择 如果你写过需要处理用户密码的代码,肯定知道不能把密码原文存进数据库。早年很多系统用 MD5 或 SHA-1 这类快速哈希算法,后来大家发现这不够安全——显卡能每秒算几十亿次哈希&#xff0c…...

AI技术如何重塑气候预测与生态保护

1. NVIDIA GTC 2025:AI如何重塑气候与生态韧性技术版图 当全球平均气温持续突破历史记录,当极端天气事件开始以月为单位刷新灾害统计,我们正面临着一个前所未有的挑战:如何用技术手段为脆弱的生态系统构筑韧性防线。今年3月17-21日…...

GD32选型不再纠结:5分钟用官方工具找到最适合你项目的MCU(附实战案例)

GD32选型实战指南:5步精准匹配工业级MCU方案 打开兆易创新官网的产品搜索器页面,工程师们常会面对370余款GD32型号陷入选择困难——主频从48MHz到240MHz不等,Flash容量覆盖16KB到3072KB,外设组合更是千差万别。去年为某工业网关项…...

短视频智能获客系统完整版:支持抖音/快手/视频号,含管理后台+手机端

温馨提示:文末有资源获取方式短视频赛道越来越卷,光靠人工剪辑发布已经跟不上节奏了。最近把一套能同时管理多个平台账号的系统跑通了,整理一下核心功能,给有需要的朋友参考。一、多平台统一管理支持抖音、快手、视频号、小红书、…...

STK Orbit Wizard隐藏技巧:除了闪电轨道,这些特殊轨道参数你调对了吗?

STK Orbit Wizard隐藏技巧:除了闪电轨道,这些特殊轨道参数你调对了吗? 在卫星轨道设计的进阶领域,Orbit Wizard常被视为STK软件中的"魔法工具箱"。许多工程师能熟练生成闪电轨道这类标志性轨道,却对参数间的…...

从OCV到AOCV:深度解析基于Stage与Distance的时序降额表实战

1. 传统OCV的痛点与AOCV的诞生 在芯片时序分析领域,OCV(On-Chip Variation)曾经是处理工艺偏差的主流方法。想象一下,你是一位厨师,为了保证菜品质量,每次做菜时都假设所有食材都是最差品质——这显然会导致…...

别再手动查表了!用Python脚本自动匹配PyTorch、torchvision、torchaudio版本(附代码)

解放双手!用Python自动化获取PyTorch生态兼容版本的全套方案 每次新建PyTorch项目时,最头疼的莫过于手动查找torchvision、torchaudio等配套库的兼容版本。官方文档的版本对应表不仅更新频繁,不同子项目还分散在各个仓库。更糟的是&#xff0…...

成本杀手!用两个三极管搞定MOS管驱动,从电平转换到‘假推挽’避坑全攻略

低成本MOS驱动设计实战:三极管方案从电平转换到“伪推挽”避坑指南 在硬件设计中,MOS管驱动电路的成本和可靠性常常成为工程师的两难选择。商用驱动芯片虽性能稳定但价格昂贵,而三极管搭建的方案成本低廉却暗藏玄机。本文将带你深入两个三极管…...

别再搞混了!OpenLayers中Feature与Layer的交互指南(附封装函数)

OpenLayers要素与图层交互实战:从原理到封装 当我们第一次在OpenLayers中创建地图应用时,最令人困惑的莫过于要素(Feature)、图层(Layer)和数据源(Source)这三者之间的关系。很多开发者都曾遇到过这样的场景:点击地图上的某个要素想要获取其所…...

RK3588音频子系统DTS配置避坑:为什么你的ES8388声卡没声音?

RK3588音频子系统DTS配置深度排查:ES8388无声问题的系统性解决方案 当你在RK3588平台上调试ES8388音频编解码器时,最令人沮丧的莫过于所有配置看起来都正确,但系统就是死活不出声。这种问题往往不是单一因素导致的,而是多个环节的…...

别再傻傻用乘除了!C/C++里用移位操作给代码提速(附性能对比测试)

移位操作 vs 乘除运算:现代C/C性能优化的实测指南 在嵌入式系统开发、高频交易算法或游戏引擎优化中,每一纳秒的延迟都可能成为瓶颈。传统教材常建议用移位操作替代乘除法来提升效率,但在现代编译器和多架构环境下,这种优化是否依…...

告别串口扩展坞!用CH344Q芯片自己动手做一个高速USB转4串口模块(附完整原理图)

从零打造高速USB转4串口模块:CH344Q实战指南 在嵌入式开发和硬件调试过程中,多串口设备的需求日益增长。传统方案往往依赖笨重的串口扩展坞或价格高昂的商业模块,而今天我们将探索一种更灵活、更具性价比的解决方案——基于CH344Q芯片自主设计…...

合宙ESP32C3新手避坑指南:从驱动安装到手势识别模块实战(附完整PlatformIO配置)

合宙ESP32C3开发板实战:从零搭建手势识别系统 第一次拿到合宙ESP32C3开发板时,我像大多数初学者一样兴奋又忐忑。这块搭载RISC-V内核的小板子,价格亲民却性能不俗,尤其适合物联网和智能家居项目。但当我真正开始连接PAJ7620手势识…...

CANoe COM接口避坑指南:Python调用时Type Library和CastTo的那些‘坑’与最佳实践

CANoe COM接口避坑指南:Python调用时Type Library和CastTo的那些‘坑’与最佳实践 当你第一次用Python脚本调用CANoe COM接口时,可能会被突如其来的报错搞得措手不及。明明按照文档写的代码,却弹出"对象不支持此属性或方法"的错误提…...

告别抓瞎!保姆级教程:在Ubuntu虚拟机里用Qt Creator远程调试i.MX6开发板(附完整配置流程)

嵌入式开发实战:Qt Creator远程调试i.MX6开发板全流程解析 在嵌入式开发领域,调试环节往往是新手工程师的"拦路虎"。当你的代码在开发板上运行异常时,能否快速定位问题直接决定了开发效率。本文将带你深入掌握Qt Creator远程调试i.…...

PLINK实战:用--indep-pairwise和R脚本搞定GWAS杂合率质控(附完整代码)

PLINK实战指南:GWAS杂合率质控全流程解析与代码实现 在基因组关联分析(GWAS)中,数据质量直接影响研究结果的可靠性。杂合率异常可能暗示样本污染或近亲繁殖等问题,而PLINK作为GWAS分析的瑞士军刀,配合R语言的数据处理能力&#xf…...

老系统别大意:手把手复现JBoss CVE-2015-7501反序列化漏洞(附Docker靶场搭建)

老系统安全警钟:实战复现JBoss反序列化漏洞与防御思考 老旧系统就像企业网络中的"定时炸弹",看似平静却暗藏危机。2015年曝光的JBoss反序列化漏洞(CVE-2015-7501)至今仍在不少企业的内网系统中存在,成为攻击…...

OptiSystem应用:光放大器EDFA的仿真

Optisystem可以设计和模拟光纤放大器和光纤激光器。此处展示的案例可在Optisystem安装文件夹samplesOptical amplifiers中找到。该教程将会介绍光放大器库这一部分。光放大器全局参数使用Optisystem的第一步是设置全局参数。我们都知道,主要的一个参数是time window…...

2025届必备的AI学术神器实际效果

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 旨在识别学术文本里由人工智能生成内容的维普AIGC检测系统,能给高校、期刊以及科…...

从手机投屏到桌面扩展:深入拆解LT9711芯片如何让一根Type-C线实现‘全能’

从手机投屏到桌面扩展:深入拆解LT9711芯片如何让一根Type-C线实现‘全能’ 你是否曾好奇,为什么一根看似普通的Type-C线能同时完成4K视频传输、高速数据同步和100W快充?这背后隐藏着一颗名为LT9711的"全能芯片"。它就像数字世界的同…...

2026最权威的五大AI论文方案推荐

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 在借助人工智能来生成文本之际,指令的精准程度会直接对输出质量产生影响&#xf…...

从AM/FM收音机到5G手机:IQ调制技术是如何一步步成为通信标配的?

从AM/FM收音机到5G手机:IQ调制技术是如何一步步成为通信标配的? 上世纪30年代,当AM广播首次将音乐和新闻送入千家万户时,很少有人能预见这种模拟调制技术会演变成今天5G手机里复杂的数字信号处理。而连接这两个时代的核心技术纽带…...

HEPTv2:基于LSH与Transformer的高效粒子轨迹重建

1. 项目概述:HEPTv2的诞生背景与技术定位在粒子物理实验领域,带电粒子轨迹重建一直是个令人头疼的计算难题。想象一下,当质子束在大型强子对撞机(LHC)中以接近光速对撞时,每次碰撞会产生数百个带电粒子&…...

你的模型‘虚胖’了吗?聊聊PyTorch中可训练参数与总参数量的区别及优化思路

你的模型‘虚胖’了吗?聊聊PyTorch中可训练参数与总参数量的区别及优化思路 在深度学习模型开发中,我们常常会关注两个关键指标:总参数量(Params)和可训练参数量(Trainable Params)。这两个数字…...