# Tab 标签页 ## 基本用法 `value` 为绑定值,可以为 number 类型(选中的tab的下标)和 string 类型(标签名)。 > 当`value`为`number`类型时,`wd-tab`可以不必设置`name`。同时如果value超出了tab数量,会用0自动兜底 ```html 内容{{item + 1}} ``` ```css .content{ line-height: 120px; text-align: center; } ``` ## 滑动动画 设置 `animated` 属性,开启tab切换动画。 ```html 内容{{item + 1}} ``` ## 粘性布局 设置 `sticky` 属性,使用粘性布局。可以设置 `offset-top` 属性,当距离窗口顶部多少像素时,固定标签头。 ```html 内容{{item + 1}} ``` ## 禁用Tab 在 `wd-tab` 上设置 `disabled` 属性,禁用某个页签。 ```html 内容{{item + 1}} ``` ## 点击事件 监听页签的点击事件. ```html 内容{{item + 1}} ``` ```javascript Page({ data: { tab: 0 }, handleClick ({ detail: { index } }) { console.log(`点击了标签${index}`) } }) ``` ## 手势滑动 设置 `swipeable` 属性,支持手势滑动。 ```html 内容{{item + 1}} ``` --- 标签页在标签数大于等于6个时,可以滑动;当标签数大于等于10个时,将会显示导航地图,便于快速定位到某个标签。可以通过设置 `slidable-num` 修改可滑动的数量阈值;设置 `map-num` 修改显示导航地图的阈值。 ## Tabs Attributes | 参数 | 说明 | 类型 | 可选值 | 默认值 | 最低版本 | |-----|------|-----|-------|-------|---------| | value | 绑定值 | string / number | - | - | - | | slidable-num | 可滑动的标签数阈值 | number | - | 6 | - | | map-num | 显示导航地图的标签数阈值 | number | - | 10 | - | | sticky | 粘性布局 | boolean | - | false | - | | offset-top | 粘性布局时距离窗口顶部距离 | number | - | 0 | - | | ~~animated~~ | ~~开启切换动画~~,2.3.0 版本修改 tabs 切换方案,去掉该属性 | boolean | - | false | - | | swipeable | 开启手势滑动 | boolean | - | false | - | | ~~lazy-render~~ | ~~懒渲染标签页~~,2.3.0 版本修改 tabs 切换方案,去掉该属性 | boolean | - | false | - | ## Tab Attributes | 参数 | 说明 | 类型 | 可选值 | 默认值 | 最低版本 | |-----|------|-----|-------|-------|--------| | name | 标签页名称 | string | - | - | - | | title | 标题 | string | - | - | - | | disabled | 禁用 | boolean | - | false | - | ## Tabs Events | 事件名称 | 说明 | 参数 | 最低版本 | |---------|-----|-----|---------| | bind:change | 绑定值变化时触发 | event.detail = { index, name },index为tab下标,name为tab绑定的值 | - | | bind:click | 点击标题时触发 | event.detail = { index, name },index为tab下标,name为tab绑定的值 | - | | bind:disabled | 点击禁用的标题时触发| event.detail = { index, name },index为tab下标,name为tab绑定的值 | - |