更新记录
1.0.0(2026-04-30) 下载此版本
- 支持 uni-tab-bar 组件
平台兼容性
uni-app x(5.0)
| Chrome | Safari | Android | iOS | 鸿蒙 | 微信小程序 |
|---|---|---|---|---|---|
| √ | √ | √ | √ | √ | √ |
uni_modules/uni-tab-bar 包括一组 tab 相关组件:
uni-tab:最外层容器,负责激活索引、内容区高度和切换事件uni-tab-bar:底部 tab 容器,负责底栏布局、安全区和中间按钮占位uni-tab-item:普通 tab 项,负责插槽展示和 badgeuni-tab-midbutton:中间悬浮按钮占位容器uni-tab-content:上方内容区域容器,负责内容注册、懒渲染和显示切换
基础用法
<template>
<uni-tab style="flex: 1" :active-index="activeIndex" @change="handleChange">
<uni-tab-content>
<scroll-view style="flex: 1">
<view>
<text>内容一</text>
</view>
</scroll-view>
</uni-tab-content>
<uni-tab-content>
<view>
<text>内容二</text>
</view>
</uni-tab-content>
<uni-tab-bar>
<uni-tab-item>
<text>首页</text>
</uni-tab-item>
<uni-tab-item badge-text="8">
<text>消息</text>
</uni-tab-item>
</uni-tab-bar>
</uni-tab>
</template>
如果需要自定义底栏主体高度,请在 uni-tab 上使用 tab-bar-height 属性。使用该属性可以更快的计算布局,而不必在页面onReady后通过getBoundRect来计算布局:
<uni-tab style="flex: 1" :active-index="activeIndex" :tab-bar-height="40" @change="handleChange">
...
</uni-tab>
组件 API
uni-tab
事件
| 事件名 | 返回参数 | 说明 |
|---|---|---|
change |
index: number |
点击普通 tab 项切换后触发,返回新的激活索引 |
uni-tab-bar
无专用属性和API,可直接通过 class / style 自定义底栏外观。
uni-tab-content
无专用属性和API,可直接通过 class / style 自定义外观。
多个选项卡内容揉在一个uni-tab中比较乱,一般推荐uni-tab-content下放一个子组件,子组件作为独立uvue文件。
各个uni-tab-content的子组件,在显示和隐藏的没有生命周期。 如需监听显示/隐藏需要通过provide/inject方式从外层传入响应式变量activeIndex,然后在子组件中watch这个activeIndex。
使用注意事项
uni-tab所在的页面不应该滚动,应该在pages.json中配置页面style为disableScroll:true。- 屏幕变化适配,Android需HBuilderX 5.09+支持。之前版本组件里无法监听页面的onResize。
uni-tab-content与uni-tab-item的数量必须一致,顺序也必须一一对应,否则切换后的内容会错位。uni-tab默认占满页面的宽度和高度,即style="flex: 1"- 自定义底栏高度时,不要只改样式高度,要同步通过
tab-bar-height传入uni-tab,这样内容区底部留白和安全区计算才会一起更新。 - 如果底栏存在镂空、下凹或透明边缘,需要让底部内容透出来,请在
uni-tab上开启tab-content-height-full,此时内容区会延伸到uni-tab-bar下方。 uni-tab-content采用“首次激活再渲染”的策略;第一次切入前不会创建实例,切走后只隐藏不销毁,适合保留 tab 内部状态。uni-tab-item只负责普通 tab 项注册与展示,不提供单独点击事件;请统一监听uni-tab的change。- 使用
uni-tab-midbutton时,中间按钮左右两侧的普通uni-tab-item数量需要相等,也就是普通项总数必须为偶数,才能保持居中均分布局。 uni-tab-midbutton只负责预留中间按钮位置,不参与激活索引计算;中间按钮点击行为需要在插槽内部自行处理。badge-text传空字符串时显示红点,传'0'时不显示;如果需要自定义 badge 外观,请使用badge-class覆盖样式。uni-tab-bar、uni-tab-item、uni-tab-content的根节点都支持直接挂class/style,推荐把视觉差异放在页面侧处理,不要改组件内部逻辑。

收藏人数:
https://gitcode.com/dcloud/uni-ui-x
下载插件并导入HBuilderX
下载示例项目ZIP
赞赏(0)
下载 2
赞赏 0
下载 11757985
赞赏 1911
赞赏
京公网安备:11010802035340号