UniApp 组件 u-tabs 详细讲解

基本用法

u-tabs 是一个选项卡组件,通过在 <u-tabs> 标签中插入多个 <u-tab> 标签来实现多个选项卡之间的切换。每个 <u-tab> 标签作为一个选项卡,可以设置标题和对应的内容。

下面是一个基本的示例:

javascript 复制代码
<u-tabs :current="currentTab" @change="tabChange">
  <u-tab title="Tab 1">Content 1</u-tab>
  <u-tab title="Tab 2">Content 2</u-tab>
  <u-tab title="Tab 3">Content 3</u-tab>
</u-tabs>

在这个示例中,currentTab 是当前选中的选项卡索引值,通过 @change 事件监听选项卡的切换。

属性讲解

1. current

  • 类型:Number
  • 默认值:0

该属性指定当前选中的选项卡的索引值,可以使用 v-model 进行双向绑定。

2. duration

  • 类型:Number
  • 默认值:300

该属性设置选项卡切换动画的时长,单位为毫秒。

3. easing-function

  • 类型:String
  • 默认值:"ease-out"

该属性设置选项卡切换动画的缓动函数,可选的值包括 "linear"、"ease"、"ease-in"、"ease-out"、"ease-in-out" 等。

4. swipeable

  • 类型:Boolean
  • 默认值:true

该属性指定是否启用滑动切换选项卡的功能。当设置为 true 时,用户可以通过左右滑动手势来切换选项卡。

5. animation

  • 类型:String
  • 默认值:无

该属性配置选项卡切换的动画效果。可以设置为 "slide"(左右滑动切换)、"fade"(淡入淡出切换)或自定义动画名称(需要在全局样式中定义)。

事件讲解

1. @change

该事件在选项卡切换时触发。通过回调函数的参数可以获取当前选中的选项卡索引值。

html 复制代码
<u-tabs :current="currentTab" @change="tabChange">
  <!-- ... -->
</u-tabs>
javascript 复制代码
methods: {
  tabChange(index) {
    console.log('当前选中的选项卡索引:', index);
  }
}

Slot 插槽

1. u-tab

用于放置单个选项卡的内容,可以在 <u-tab> 标签内部插入任意内容。

html 复制代码
<u-tabs :current="currentTab">
  <u-tab title="Tab 1">
    <div>Content 1</div>
    <p>More content...</p>
  </u-tab>
  <u-tab title="Tab 2">
    <!-- Content for Tab 2 -->
  </u-tab>
</u-tabs>

2. u-tabs-left

在左侧插入额外的内容。可以在 <u-tabs-left> 标签内部插入其他组件或标签。

html 复制代码
<u-tabs :current="currentTab">
  <u-tabs-left>
    <!-- Insert additional content on the left -->
  </u-tabs-left>
  <u-tab title="Tab 1">Content 1</u-tab>
  <u-tab title="Tab 2">Content 2</u-tab>
</u-tabs>

3. u-tabs-right

在右侧插入额外的内容。可以在 <u-tabs-right> 标签内部插入其他组件或标签。

html 复制代码
<u-tabs :current="currentTab">
  <u-tab title="Tab 1">Content 1</u-tab>
  <u-tab title="Tab 2">Content 2</u-tab>
  <u-tabs-right>
    <!-- Insert additional content on the right -->
  </u-tabs-right>
</u-tabs>

以上是对于 UniApp 组件 u-tabs 的详细讲解。通过使用 u-tabs 组件,您可以轻松地创建具有选项卡切换功能的界面。

相关推荐
里欧跑得慢1 小时前
17. Flutter Hero动画实现:让界面过渡更加优雅
前端·css·flutter·web
IT_陈寒2 小时前
Vue的这个响应式陷阱,我debug了一整天才爬出来
前端·人工智能·后端
kyriewen2 小时前
前端测试:别为了100%覆盖率而写测试,那是自欺欺人
前端·javascript·单元测试
去伪存真2 小时前
我自己写的第一个skills--project-core-standards
前端·agent
Data_Journal2 小时前
如何使用cURL更改User Agent
大数据·服务器·前端·javascript·数据库
竹林8182 小时前
wagmi v2 多链钱包切换:一个 Uniswap 仿盘项目让我踩了三天坑
前端·javascript
donecoding3 小时前
Playwright MCP 页面捕获:Snapshot、截图、HTML 到底选哪个?
前端·ai编程·前端工程化
滕青山3 小时前
在线PDF拆分工具核心JS实现
前端·javascript·vue.js
Smilezyl3 小时前
一个独立开发者,靠一份 markdown 驱动 Claude Code, 用 20 天跑通 9 个包的 monorepo 工程
前端·人工智能·github
技术崽崽3 小时前
不止有 Agent:Cursor 进阶使用技巧全解析
前端