mirror of
				https://gitee.com/vant-contrib/vant.git
				synced 2025-10-31 03:22:08 +08:00 
			
		
		
		
	
		
			
				
	
	
	
		
			5.1 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	
			5.1 KiB
		
	
	
	
	
	
	
	
Tab 标签页
使用指南
import { Tab, Tabs } from 'vant';
Vue.use(Tab).use(Tabs);
代码演示
基础用法
默认情况下启用第一个标签,可以通过v-model绑定当前激活的标签索引
<van-tabs v-model="active">
  <van-tab title="标签 1">内容 1</van-tab>
  <van-tab title="标签 2">内容 2</van-tab>
  <van-tab title="标签 3">内容 3</van-tab>
  <van-tab title="标签 4">内容 4</van-tab>
</van-tabs>
export default {
  data() {
    return {
      active: 2
    };
  }
}
横向滚动
多于 4 个标签时,Tab 可以横向滚动
<van-tabs>
  <van-tab v-for="index in 8" :title="'标签 ' + index">
    内容 {{ index }}
  </van-tab>
</van-tabs>
禁用标签
设置disabled属性即可禁用标签。如果需要监听禁用标签的点击事件,可以在van-tabs上监听disabled事件
<van-tabs @disabled="onClickDisabled">
  <van-tab title="标签 1">内容 1</van-tab>
  <van-tab title="标签 2" disabled>内容 2</van-tab>
  <van-tab title="标签 3">内容 3</van-tab>
</van-tabs>
export default {
  methods: {
    onClickDisabled(index, title) {
      this.$toast(title + '已被禁用');
    }
  }
};
样式风格
Tab支持两种样式风格:line和card,默认为line样式,可以通过type属性修改样式风格
<van-tabs type="card">
  <van-tab title="标签 1">内容 1</van-tab>
  <van-tab title="标签 2">内容 2</van-tab>
  <van-tab title="标签 3">内容 3</van-tab>
</van-tabs>
点击事件
可以在van-tabs上绑定click事件,事件传参为标签对应的索引和标题
<van-tabs @click="onClick">
  <van-tab title="标签 1">内容 1</van-tab>
  <van-tab title="标签 2">内容 2</van-tab>
</van-tabs>
export default {
  methods: {
    onClick(index, title) {
      this.$toast(title);
    }
  }
};
粘性布局
通过sticky属性可以开启粘性布局,粘性布局下,当 Tab 滚动到顶部时会自动吸顶
<van-tabs v-model="active" sticky>
  <van-tab v-for="index in 4" :title="'选项 ' + index">
    内容 {{ index }}
  </van-tab>
</van-tabs>
自定义标签
通过 title 插槽可以自定义标签内容
<van-tabs v-model="active">
  <van-tab v-for="index in 2">
    <div slot="title">
      <van-icon name="more-o" />选项
    </div>
    内容 {{ index }}
  </van-tab>
</van-tabs>
切换动画
通过animated属性可以开启切换标签内容时的转场动画
<van-tabs v-model="active" animated>
  <van-tab v-for="index in 4" :title="'选项 ' + index">
    内容 {{ index }}
  </van-tab>
</van-tabs>
滑动切换
通过swipeable属性可以开启滑动切换标签页
<van-tabs v-model="active" swipeable>
  <van-tab v-for="index in 4" :title="'选项 ' + index">
    内容 {{ index }}
  </van-tab>
</van-tabs>
Tabs API
| 参数 | 说明 | 类型 | 默认值 | 版本 | 
|---|---|---|---|---|
| v-model | 当前标签的索引 | StringNumber | 0 | 1.0.6 | 
| type | 样式类型,可选值为 card | String | line | - | 
| duration | 动画时间,单位秒 | Number | 0.3 | - | 
| background | 标签栏背景色 | String | white | 1.6.5 | 
| line-width | 底部条宽度,单位 px | Number | - | 1.1.1 | 
| line-height | 底部条高度,单位 px | Number | 3 | 1.5.0 | 
| color | 标签主题色 | String | #f44 | 1.2.0 | 
| title-active-color | 标题选中态颜色 | String | - | 1.6.5 | 
| title-inactive-color | 标题默认态颜色 | String | - | 1.6.5 | 
| swipeable | 是否开启手势滑动切换 | Boolean | false | 1.0.0 | 
| sticky | 是否使用粘性定位布局 | Boolean | false | - | 
| offset-top | 粘性定位布局下与顶部的最小距离,单位 px | Number | 0 | 1.1.15 | 
| swipe-threshold | 滚动阈值,标签数量超过多少个可滚动 | Number | 4 | - | 
| animated | 是否开启切换标签内容时的转场动画 | Boolean | false | 1.4.5 | 
| ellipsis | 是否省略过长的标题文字 | Boolean | true | 1.5.0 | 
| lazy-render | 是否开启标签页内容延迟渲染 | Boolean | true | 1.6.6 | 
Tab API
| 参数 | 说明 | 类型 | 默认值 | 版本 | 
|---|---|---|---|---|
| title | 标题 | String | - | - | 
| disabled | 是否禁用标签 | Boolean | false | - | 
Tabs Slot
| 名称 | 说明 | 
|---|---|
| nav-left | 标题左侧内容 | 
| nav-right | 标题右侧内容 | 
Tab Slot
| 名称 | 说明 | 
|---|---|
| default | 标签页内容 | 
| title | 自定义标签 | 
Tabs Event
| 事件名 | 说明 | 参数 | 
|---|---|---|
| click | 点击标签时触发 | index:标签索引,title:标题 | 
| change | 当前激活的标签改变时触发 | index:标签索引,title:标题 | 
| disabled | 点击被禁用的标签时触发 | index:标签索引,title:标题 | 
| scroll | 滚动时触发,仅在 sticky 模式下生效 | { scrollTop: 距离顶部位置, isFixed: 是否吸顶 } |