UNPKG

drip-ui

Version:

Lightweight Mobile UI Components built on Vue

179 lines (140 loc) 4.58 kB
## 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: 是否吸顶 } |