## Tab 标签页

### 使用指南
``` javascript
import { Tabtem, Tabs } from 'drip-ui';

Vue.use(Tabtem).use(Tabs);
```

### 代码演示

#### 基础用法

默认情况下启用第一个标签，可以通过`v-model`绑定当前激活的标签索引

```html
<drip-tabs v-model="active">
  <drip-tab-item title="标签 1">内容 1</drip-tab-item>
  <drip-tab-item title="标签 2">内容 2</drip-tab-item>
  <drip-tab-item title="标签 3">内容 3</drip-tab-item>
  <drip-tab-item title="标签 4">内容 4</drip-tab-item>
</drip-tabs>
```

```js
export default {
  data() {
    return {
      active: 2
    };
  }
}
```

#### 横向滚动

多于 4 个标签时，Tab 可以横向滚动

```html
<drip-tabs>
  <drip-tab-item v-for="index in 8" :title="'标签 ' + index">
    内容 {{ index }}
  </drip-tab-item>
</drip-tabs>
```

#### 禁用标签

设置`disabled`属性即可禁用标签。如果需要监听禁用标签的点击事件，可以在`drip-tabs`上监听`disabled`事件

```html
<drip-tabs @disabled="onClickDisabled">
  <drip-tab-item title="标签 1">内容 1</drip-tab-item>
  <drip-tab-item title="标签 2" disabled>内容 2</drip-tab-item>
  <drip-tab-item title="标签 3">内容 3</drip-tab-item>
</drip-tabs>
```

```javascript
export default {
  methods: {
    onClickDisabled(index, title) {
      this.$toast(title + '已被禁用');
    }
  }
};
```

#### 样式风格

`tab-item`支持三种样式风格：`line`、`square` 和`card`，默认为`line`样式，可以通过`type`属性修改样式风格

```html
<drip-tabs type="card">
  <drip-tab-item title="标签 1">内容 1</drip-tab-item>
  <drip-tab-item title="标签 2">内容 2</drip-tab-item>
  <drip-tab-item title="标签 3">内容 3</drip-tab-item>
</drip-tabs>
```

#### 点击事件

可以在`drip-tabs`上绑定`click`事件，事件传参为标签对应的索引和标题

```html
<drip-tabs @click="onClick">
  <drip-tab-item title="标签 1">内容 1</drip-tab-item>
  <drip-tab-item title="标签 2">内容 2</drip-tab-item>
</drip-tabs>
```

```javascript
export default {
  methods: {
    onClick(index, title) {
      this.$toast(title);
    }
  }
};
```

#### 粘性布局

通过`sticky`属性可以开启粘性布局，粘性布局下，当 tab-item 滚动到顶部时会自动吸顶

```html
<drip-tabs v-model="active" sticky>
  <drip-tab-item v-for="index in 4" :title="'选项 ' + index">
    内容 {{ index }}
  </drip-tab-item>
</drip-tabs>
```

#### 自定义标签

通过 title 插槽可以自定义标签内容

```html
<drip-tabs v-model="active">
  <drip-tab-item v-for="index in 2">
    <div slot="title">
      <drip-icon name="more-o" />选项
    </div>
    内容 {{ index }}
  </drip-tab-item>
</drip-tabs>
```

#### 滑动切换

通过`swipeable`属性可以开启滑动切换tab

```html
<drip-tabs v-model="active" swipeable>
  <drip-tab-item v-for="index in 4" :title="'选项 ' + index">
    内容 {{ index }}
  </drip-tab-item>
</drip-tabs>
```

### Tabs API

| 参数 | 说明 | 类型 | 默认值 | 版本 |
|------|------|------|------|------|
| v-model | 当前标签的索引 | `String` `Number` | `0` | 1.0.6 |
| color | active 标签颜色 | `String` | `#f44` | 1.2.0 |
| normalColor | 标签颜色 | `String` | | |
| fontSize | 字体大小 | `Number` | | |
| type | 样式类型，可选值为`card` | `String` | `line` | - |
| duration | 动画时间，单位秒 | `Number` | `0.2` | - |
| line-width | 底部条宽度，单位 px | `Number` | - | 1.1.1 |
| swipeable | 是否开启手势滑动切换 | `Boolean` | `false` | 1.0.0 |
| sticky | 是否使用粘性定位布局 | `Boolean` | `false` | - |
| offset-top | 粘性定位布局下与顶部的最小距离，单位 px | `Number` | `0` | 1.1.15 |
| swipe-threshold | 滚动阈值，标签数量超过多少个可滚动 | `Number` | `4` | - |

### tab-item API

| 参数 | 说明 | 类型 | 默认值 | 版本 |
|------|------|------|------|------|
| title | 标题 | `String` | - | - |
| disabled | 是否禁用标签 | `Boolean` | `false` | - |

### tab-item Slot

| 名称 | 说明 |
|------|------|
| - | 标签页内容 |
| title | 自定义标签 |

### Tabs Event

| 事件名 | 说明 | 参数 |
|------|------|------|
| click | 点击标签时触发 | index：标签索引，title：标题 |
| change | 当前激活的标签改变时触发 | index：标签索引，title：标题 |
| disabled | 点击被禁用的标签时触发 | index：标签索引，title：标题 |
| scroll | 滚动时触发 | { scrollTop: 距离顶部位置, isFixed: 是否吸顶 } |
