HarmonyOS6 ArkTS Tabs 设置TabBar的布局模式

HarmonyOS6 ArkTS Tabs 设置TabBar的布局模式

文章目录

Tabs与TabBar基础

Tabs组件由TabBar(页签导航栏)和TabContent(对应内容区)两部分组成。TabBar作为导航入口,其布局模式直接影响页面美观与操作流畅度。

核心属性:barMode

  • 作用:定义TabBar的布局规则,控制页签宽度分配与滚动能力
  • 类型BarMode枚举,包含两种核心模式
    • BarMode.Fixed固定均分模式(默认值)
    • BarMode.Scrollable可滚动模式
  • 配置位置Tabs组件的链式调用属性

两种布局模式

1. BarMode.Fixed(固定均分模式)

核心特性
  • 宽度均分:所有TabBar页签自动平均分配TabBar总宽度,每个页签宽度完全一致
  • 不可滚动TabBar区域固定,无法横向滑动,页签数量超出屏幕宽度时会被挤压截断
  • 布局稳定:页签位置固定,适合数量少、内容固定的导航场景
适用场景
  • 应用底部导航栏(通常3-5个固定页签,如首页、分类、我的)
  • 页签数量固定且较少(≤5个),无需动态扩展的场景
  • 要求导航栏布局稳定、无滚动行为的界面
代码配置
Tabs(){// TabContent定义...}.barMode(BarMode.Fixed)// 配置固定均分模式

2. BarMode.Scrollable(可滚动模式)

核心特性
  • 自适应宽度:每个TabBar页签宽度由内容(文字/图标)实际长度决定,非强制均分
  • 支持滚动:当所有页签总宽度超出TabBar容器宽度时,可横向滑动显示隐藏页签
  • 布局灵活:适配大量页签场景,内容展示更完整
适用场景
  • 应用顶部分类导航(如新闻频道、商品分类,页签数量多且不固定)
  • 页签文字长度差异大、需自适应宽度的场景
  • 动态增减页签、内容可扩展的导航界面
代码配置
Tabs(){// TabContent定义...}.barMode(BarMode.Scrollable)// 配置可滚动模式

完整代码

// xxx.ets@Entry@Component struct TabsExample {@State text:string='文本';@State barMode: BarMode = BarMode.Fixed;build(){Column(){// 文本控制按钮Row(){Button('文本增加 ').width('47%').height(50).backgroundColor(Color.Blue).fontColor(Color.White).borderRadius(12).onClick(()=>{this.text +='文本增加';}).margin({ right:'6%', bottom:12})Button('文本重置').width('47%').height(50).backgroundColor(Color.Orange).fontColor(Color.White).borderRadius(12).onClick(()=>{this.text ='文本';}).margin({ bottom:12})}// 模式切换按钮Row(){Button('Fixed固定模式').width('47%').height(50).backgroundColor('#0088ff').fontColor(Color.White).borderRadius(12).onClick(()=>{this.barMode = BarMode.Fixed;}).margin({ right:'6%', bottom:12})Button('Scrollable滚动模式').width('47%').height(50).backgroundColor('#33bb33').fontColor(Color.White).borderRadius(12).onClick(()=>{this.barMode = BarMode.Scrollable;}).margin({ bottom:12})}// 核心 Tabs 组件Tabs(){TabContent(){Column().width('100%').height('100%').backgroundColor(Color.Pink)}.tabBar(`${this.text} 页面1`)TabContent(){Column().width('100%').height('100%').backgroundColor(Color.Green)}.tabBar(`${this.text} 页面2`)TabContent(){Column().width('100%').height('100%').backgroundColor(Color.Blue)}.tabBar(`${this.text} 页面3`)}.height('60%').backgroundColor(0xf1f3f5).barMode(this.barMode).scrollable(true).animationDuration(300)}.width('100%').height('100%').padding(24)}}

运行效果图:

点击文本增加使文案增多,然后点击滚动模式,文案可以左右滑动:

模式效果对比

效果对比表

对比维度BarMode.FixedBarMode.Scrollable
页签宽度强制均分,宽度一致自适应内容,宽度不一
滚动能力不可滚动,超出挤压可横向滑动,完整展示
文字长度影响文字过长会被截断文字自适应宽度,无挤压
适用页签数量少量(3-5个)大量(≥5个)
布局稳定性高,位置固定中,可滑动调整

总结

Tabs组件的barMode属性是配置TabBar布局的核心,BarMode.Fixed适合固定少标签场景,BarMode.Scrollable适配多标签、动态内容场景。开发中需根据导航位置、页签数量、内容特性选择合适模式,结合样式配置(指示器、文字颜色)优化UI体验,打造符合HarmonyOS设计规范的高质量应用界面。

如果这篇文章对你有帮助,欢迎点赞、收藏、关注,你的支持是持续创作的动力

Read more

Home Assistant界面美化终极指南:从零开始打造个性化智能家居界面

Home Assistant界面美化终极指南:从零开始打造个性化智能家居界面 【免费下载链接】frontend:lollipop: Frontend for Home Assistant 项目地址: https://gitcode.com/gh_mirrors/frontend149/frontend 想要让智能家居控制界面既美观又实用吗?Home Assistant提供了强大的界面定制功能,让你可以完全掌控界面的视觉风格。本指南将带你从基础设置到高级技巧,一步步打造专属于你的智能家居美学体验。 为什么你的Home Assistant界面需要美化? 界面美化不仅仅是改变颜色,它能显著提升你的智能家居使用体验: * 视觉舒适度:长时间使用不会造成眼睛疲劳 * 个性化表达:界面风格与你的家居装修完美融合 * 操作效率:优化的布局让控制更加直观便捷 * 多设备适配:确保在不同屏幕尺寸下都有最佳显示效果 快速上手:基础美化设置 如何访问主题设置界面 在Home Assistant主界面中,点击右上角的个人资料图标,选择"主题"选项,即可开始你的美化之旅。系统内置了多

为什么Fun-ASR部署总失败?GPU适配问题保姆级教程解析

为什么Fun-ASR部署总失败?GPU适配问题保姆级教程解析 你是不是也遇到过这种情况?兴致勃勃地下载了Fun-ASR,准备体验一下这个强大的语音识别模型,结果在部署环节就卡住了。命令行里报出一堆看不懂的CUDA错误,或者模型加载到一半就内存溢出,屏幕上一片红字,让人瞬间头大。 “明明按照教程来的,为什么我的就不行?” 这可能是很多朋友的心声。今天,我们就来彻底解决这个问题。Fun-ASR部署失败,十有八九是GPU环境没配好。别担心,这篇保姆级教程会带你一步步排查,从环境检查到问题修复,手把手让你把Fun-ASR稳稳地跑起来。 1. 部署失败的“罪魁祸首”:GPU环境问题深度剖析 在开始动手之前,我们先搞清楚为什么Fun-ASR这么“挑食”。它本质上是一个深度神经网络模型,计算量巨大。为了达到实时或准实时的识别速度,它必须依赖GPU进行加速。如果你的GPU环境有任何“不兼容”,它就会立刻“罢工”。 常见的部署失败,可以归结为以下几类核心问题: 1.1 CUDA版本不匹配:驱动、工具包与PyTorch的“三角关系” 这是最常见的问题。你需要理解这三者之间的关系: * G

具身神经-机器人运控通讯架构与实现系列

具身智能热潮之下,大量企业投身具身行业。在机器人本体控制方案上各家争鸣,但是试错路径太长,不少团队会在底层控制方案上走大量的弯路,导致资源浪费、项目延期甚至破产。 以第一性原则,探索当前具身机器人通讯架构实现最优解,加速具身机器人行业底层控制(通讯)系统技术方向收敛。尽可能帮助机器人本体系统工程师减少试错。 本系列仅针对机器人本体控制系统底层通讯部分:小脑<--->执行器/传感器之间的架构和具体实现。 gitee链接:https://gitee.com/Lenz_s_law/embodied-nerve 博文汇总 欢迎投稿 通讯架构分析篇 * MIT开源四足机器狗通讯架构分析 * 智元灵犀X1通讯分析1-整机通讯架构 * 智元灵犀X1通讯分析2-CANFD性能优化 * 宇树G1主控拆解分析 * RS485、CAN/FD、EtherCAT三种主流机器人总线方案分析 CAN/FD技术篇 * CAN/FD总线性能分析-机器人应用 * 机器人CAN/FD总线通讯架构设计 * 机器人CAN/FD接口关键性能指标 * 机器人CAN/FD接口扩展/实现方案