mirror of
				https://gitee.com/vant-contrib/vant.git
				synced 2025-10-26 17:22:11 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			199 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			199 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| ## Tab
 | ||
| 
 | ||
| ### Install
 | ||
| ``` javascript
 | ||
| import { Tab, Tabs } from 'vant';
 | ||
| 
 | ||
| Vue.use(Tab).use(Tabs);
 | ||
| ```
 | ||
| 
 | ||
| ### Usage
 | ||
| 
 | ||
| #### Basic Usage
 | ||
| 
 | ||
| The first tab is actived by default, you can set `v-model` to active specified tab.
 | ||
| 
 | ||
| ```html
 | ||
| <van-tabs v-model="active">
 | ||
|   <van-tab v-for="index in 4" :title="'tab' + index">
 | ||
|     content of tab {{ index }}
 | ||
|   </van-tab>
 | ||
| </van-tabs>
 | ||
| ```
 | ||
| 
 | ||
| ```js
 | ||
| export default {
 | ||
|   data() {
 | ||
|     return {
 | ||
|       active: 2
 | ||
|     };
 | ||
|   }
 | ||
| }
 | ||
| ```
 | ||
| 
 | ||
| #### Swipe Tabs
 | ||
| 
 | ||
| By default more than 4 tabs, you can scroll through the tabs. You can set `swipe-threshold` attribute to customize threshold number.
 | ||
| 
 | ||
| ```html
 | ||
| <van-tabs>
 | ||
|   <van-tab v-for="index in 8" :title="'tab' + index">
 | ||
|     content of tab {{ index }}
 | ||
|   </van-tab>
 | ||
| </van-tabs>
 | ||
| ```
 | ||
| 
 | ||
| #### Disabled Tab
 | ||
| 
 | ||
| You can set `disabled` attribute on the corresponding `van-tab`. 
 | ||
| 
 | ||
| ```html
 | ||
| <van-tabs @disabled="onClickDisabled">
 | ||
|   <van-tab v-for="index in 3" :title="'tab' + index" :disabled="index === 2">
 | ||
|     content of tab {{ index }}
 | ||
|   </van-tab>
 | ||
| </van-tabs>
 | ||
| ```
 | ||
| 
 | ||
| ```javascript
 | ||
| export default {
 | ||
|   methods: {
 | ||
|     onClickDisabled(index, title) {
 | ||
|       this.$toast(title + ' is disabled');
 | ||
|     }
 | ||
|   }
 | ||
| };
 | ||
| ```
 | ||
| 
 | ||
| #### Card Style
 | ||
| 
 | ||
| Tabs styled as cards.
 | ||
| 
 | ||
| ```html
 | ||
| <van-tabs type="card">
 | ||
|   <van-tab v-for="index in 3" :title="'tab' + index">
 | ||
|     content of tab {{ index }}
 | ||
|   </van-tab>
 | ||
| </van-tabs>
 | ||
| ```
 | ||
| 
 | ||
| #### Click Event
 | ||
| 
 | ||
| ```html
 | ||
| <van-tabs @click="onClick">
 | ||
|   <van-tab v-for="index in 2" :title="'tab' + index">
 | ||
|     content of tab {{ index }}
 | ||
|   </van-tab>
 | ||
| </van-tabs>
 | ||
| ```
 | ||
| 
 | ||
| ```javascript
 | ||
| export default {
 | ||
|   methods: {
 | ||
|     onClick(index, title) {
 | ||
|       this.$toast(title);
 | ||
|     }
 | ||
|   }
 | ||
| };
 | ||
| ```
 | ||
| 
 | ||
| #### Sticky
 | ||
| In sticky mode, the tab will be fixed to top when scroll to top
 | ||
| 
 | ||
| ```html
 | ||
| <van-tabs v-model="active" sticky>
 | ||
|   <van-tab v-for="index in 4" :title="'tab ' + index">
 | ||
|     content {{ index }}
 | ||
|   </van-tab>
 | ||
| </van-tabs>
 | ||
| ```
 | ||
| 
 | ||
| #### Custom title
 | ||
| Use title slot to custom tab title
 | ||
| 
 | ||
| ```html
 | ||
| <van-tabs v-model="active">
 | ||
|   <van-tab v-for="index in 2">
 | ||
|     <div slot="title">
 | ||
|       <van-icon name="more-o" />tab
 | ||
|     </div>
 | ||
|     content {{ index }}
 | ||
|   </van-tab>
 | ||
| </van-tabs>
 | ||
| ```
 | ||
| 
 | ||
| #### Switch Animation
 | ||
| 
 | ||
| Use `animated` props to change tabs with animation
 | ||
| 
 | ||
| ```html
 | ||
| <van-tabs v-model="active" animated>
 | ||
|   <van-tab v-for="index in 4" :title="'tab ' + index">
 | ||
|     content {{ index }}
 | ||
|   </van-tab>
 | ||
| </van-tabs>
 | ||
| ```
 | ||
| 
 | ||
| #### Swipeable
 | ||
| 
 | ||
| In swipeable mode, you can switch tabs with swipe gestrue in the content
 | ||
| 
 | ||
| ```html
 | ||
| <van-tabs v-model="active" swipeable>
 | ||
|   <van-tab v-for="index in 4" :title="'tab ' + index">
 | ||
|     content {{ index }}
 | ||
|   </van-tab>
 | ||
| </van-tabs>
 | ||
| ```
 | ||
| 
 | ||
| ### Tabs API
 | ||
| 
 | ||
| | Attribute | Description | Type | Default |
 | ||
| |------|------|------|------|
 | ||
| | v-model | Index of active tab | `String` `Number` | `0` |
 | ||
| | type | Can be set to `line` `card` | `String` | `line` |
 | ||
| | duration | Toggle tab's animation time | `Number` | `0.3` | - |
 | ||
| | background | Background color | `String` | `white` |
 | ||
| | line-width | Width of tab line (px) | `Number` | Width of active tab |
 | ||
| | line-height | Height of tab line (px) | `Number` | 3 |
 | ||
| | color | Tab color | `String` | `#f44` |
 | ||
| | title-active-color | Title active color | `String` | - |
 | ||
| | title-inactive-color | Title inactive color | `String` | - |
 | ||
| | swipe-threshold | Set swipe tabs threshold | `Number` | `4` | - |
 | ||
| | sticky | Whether to use sticky mode | `Boolean` | `false` |
 | ||
| | offset-top | Offset top when use sticky mode | `Number` | `0` |
 | ||
| | swipeable | Whether to switch tabs with swipe gestrue in the content | `Boolean` | `false` |
 | ||
| | animated | Whether to change tabs with animation | `Boolean` | `false` |
 | ||
| | ellipsis | Whether to ellipsis too long title | `Boolean` | `true` |
 | ||
| | lazy-render | Whether to enable tab content lazy render | `Boolean` | `true` |
 | ||
| 
 | ||
| ### Tab API
 | ||
| 
 | ||
| | Attribute | Description | Type | Default |
 | ||
| |------|------|------|------|
 | ||
| | title | Title | `String` | - |
 | ||
| | disabled | Whether to disable tab | `Boolean` | `false` |
 | ||
| 
 | ||
| ### Tabs Slot
 | ||
| 
 | ||
| | name | Description |
 | ||
| |------|------|
 | ||
| | nav-left | Custom nav left content |
 | ||
| | nav-right | Custom nav right content |
 | ||
| 
 | ||
| ### Tab Slot
 | ||
| 
 | ||
| | name | Description |
 | ||
| |------|------|
 | ||
| | default | Content of tab |
 | ||
| | title | Custom tab title |
 | ||
| 
 | ||
| ### Tabs Event
 | ||
| 
 | ||
| | Event | Description | Arguments |
 | ||
| |------|------|------|
 | ||
| | click | Triggered when click tab | index:index of current tab,title: tab title |
 | ||
| | change | Triggered when active tab changed | index:index of current tab,title: tab title |
 | ||
| | disabled | Triggered when click disabled tab | index:index of current tab, title: tab title |
 | ||
| | scroll | Triggered when tab scroll in sticky mode | Object: { scrollTop, isFixed } |
 |