mirror of
https://gitee.com/vant-contrib/vant-weapp.git
synced 2025-04-06 03:58:05 +08:00
[new feature] Tabbar: add active-color prop (#1145)
This commit is contained in:
parent
9d03d94aa3
commit
6fd37fc5b9
@ -1,5 +1,10 @@
|
|||||||
<demo-block title="基础用法">
|
<demo-block title="基础用法">
|
||||||
<van-tabbar active="{{ active }}" custom-class="tabbar" bind:change="onChange" safe-area-inset-bottom="{{ false }}">
|
<van-tabbar
|
||||||
|
active="{{ active }}"
|
||||||
|
custom-class="tabbar"
|
||||||
|
safe-area-inset-bottom="{{ false }}"
|
||||||
|
bind:change="onChange"
|
||||||
|
>
|
||||||
<van-tabbar-item icon="home-o">标签</van-tabbar-item>
|
<van-tabbar-item icon="home-o">标签</van-tabbar-item>
|
||||||
<van-tabbar-item icon="search" dot>标签</van-tabbar-item>
|
<van-tabbar-item icon="search" dot>标签</van-tabbar-item>
|
||||||
<van-tabbar-item icon="friends-o" info="5">标签</van-tabbar-item>
|
<van-tabbar-item icon="friends-o" info="5">标签</van-tabbar-item>
|
||||||
@ -8,13 +13,41 @@
|
|||||||
</demo-block>
|
</demo-block>
|
||||||
|
|
||||||
<demo-block title="自定义图标">
|
<demo-block title="自定义图标">
|
||||||
<van-tabbar active="{{ active2 }}" custom-class="tabbar" bind:change="onChange" safe-area-inset-bottom="{{ false }}">
|
<van-tabbar
|
||||||
|
active="{{ active2 }}"
|
||||||
|
custom-class="tabbar"
|
||||||
|
safe-area-inset-bottom="{{ false }}"
|
||||||
|
bind:change="onChange"
|
||||||
|
>
|
||||||
<van-tabbar-item info="3">
|
<van-tabbar-item info="3">
|
||||||
<span>自定义</span>
|
<image
|
||||||
<image slot="icon" src="{{ icon.normal }}" class="icon" mode="aspectFit" />
|
slot="icon"
|
||||||
<image slot="icon-active" src="{{ icon.active }}" mode="aspectFit" />
|
src="{{ icon.normal }}"
|
||||||
|
mode="aspectFit"
|
||||||
|
/>
|
||||||
|
<image
|
||||||
|
slot="icon-active"
|
||||||
|
src="{{ icon.active }}"
|
||||||
|
mode="aspectFit"
|
||||||
|
/>
|
||||||
|
自定义
|
||||||
</van-tabbar-item>
|
</van-tabbar-item>
|
||||||
<van-tabbar-item icon="search">标签</van-tabbar-item>
|
<van-tabbar-item icon="search">标签</van-tabbar-item>
|
||||||
<van-tabbar-item icon="setting-o">标签</van-tabbar-item>
|
<van-tabbar-item icon="setting-o">标签</van-tabbar-item>
|
||||||
</van-tabbar>
|
</van-tabbar>
|
||||||
</demo-block>
|
</demo-block>
|
||||||
|
|
||||||
|
<demo-block title="自定义颜色">
|
||||||
|
<van-tabbar
|
||||||
|
active="{{ active }}"
|
||||||
|
custom-class="tabbar"
|
||||||
|
safe-area-inset-bottom="{{ false }}"
|
||||||
|
active-color="#4b0"
|
||||||
|
bind:change="onChange"
|
||||||
|
>
|
||||||
|
<van-tabbar-item icon="home-o">标签</van-tabbar-item>
|
||||||
|
<van-tabbar-item icon="search">标签</van-tabbar-item>
|
||||||
|
<van-tabbar-item icon="friends-o">标签</van-tabbar-item>
|
||||||
|
<van-tabbar-item icon="setting-o">标签</van-tabbar-item>
|
||||||
|
</van-tabbar>
|
||||||
|
</demo-block>
|
||||||
|
@ -25,9 +25,9 @@ VantComponent({
|
|||||||
this.$emit('click');
|
this.$emit('click');
|
||||||
},
|
},
|
||||||
|
|
||||||
setActive(active) {
|
setActive({ active, color }) {
|
||||||
if (this.data.active !== active) {
|
if (this.data.active !== active) {
|
||||||
this.set({ active });
|
this.set({ active, color });
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
<view
|
<view
|
||||||
class="van-tabbar-item {{ active ? 'van-tabbar-item--active' : '' }}"
|
class="van-tabbar-item {{ active ? 'van-tabbar-item--active' : '' }}"
|
||||||
|
style="{{ active && color ? 'color: ' + color : '' }}"
|
||||||
bind:tap="onClick"
|
bind:tap="onClick"
|
||||||
>
|
>
|
||||||
<view class="van-tabbar-item__icon {{ dot ? 'van-tabbar-item__icon--dot' : '' }}">
|
<view class="van-tabbar-item__icon {{ dot ? 'van-tabbar-item__icon--dot' : '' }}">
|
||||||
|
@ -13,7 +13,6 @@
|
|||||||
|
|
||||||
#### 基础用法
|
#### 基础用法
|
||||||
|
|
||||||
|
|
||||||
```html
|
```html
|
||||||
<van-tabbar active="{{ active }}" bind:change="onChange">
|
<van-tabbar active="{{ active }}" bind:change="onChange">
|
||||||
<van-tabbar-item icon="home-o">标签</van-tabbar-item>
|
<van-tabbar-item icon="home-o">标签</van-tabbar-item>
|
||||||
@ -35,7 +34,6 @@ Page({
|
|||||||
});
|
});
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
#### 自定义图标
|
#### 自定义图标
|
||||||
|
|
||||||
可以通过 slot 自定义图标,其中 icon slot 代表未选中状态下的图标,icon-active slot 代表选中状态下的图标
|
可以通过 slot 自定义图标,其中 icon slot 代表未选中状态下的图标,icon-active slot 代表选中状态下的图标
|
||||||
@ -43,9 +41,17 @@ Page({
|
|||||||
```html
|
```html
|
||||||
<van-tabbar active="{{ active }}" bind:change="onChange">
|
<van-tabbar active="{{ active }}" bind:change="onChange">
|
||||||
<van-tabbar-item info="3">
|
<van-tabbar-item info="3">
|
||||||
<span>自定义</span>
|
<image
|
||||||
<image slot="icon" src="{{ icon.normal }}" class="icon" mode="aspectFit" />
|
slot="icon"
|
||||||
<image slot="icon-active" src="{{ icon.active }}" mode="aspectFit" />
|
src="{{ icon.normal }}"
|
||||||
|
mode="aspectFit"
|
||||||
|
/>
|
||||||
|
<image
|
||||||
|
slot="icon-active"
|
||||||
|
src="{{ icon.active }}"
|
||||||
|
mode="aspectFit"
|
||||||
|
/>
|
||||||
|
自定义
|
||||||
</van-tabbar-item>
|
</van-tabbar-item>
|
||||||
<van-tabbar-item icon="search">标签</van-tabbar-item>
|
<van-tabbar-item icon="search">标签</van-tabbar-item>
|
||||||
<van-tabbar-item icon="setting-o">标签</van-tabbar-item>
|
<van-tabbar-item icon="setting-o">标签</van-tabbar-item>
|
||||||
@ -68,11 +74,39 @@ Page({
|
|||||||
});
|
});
|
||||||
```
|
```
|
||||||
|
|
||||||
|
#### 自定义颜色
|
||||||
|
|
||||||
|
```html
|
||||||
|
<van-tabbar
|
||||||
|
active="{{ active }}"
|
||||||
|
active-color="#4b0"
|
||||||
|
bind:change="onChange"
|
||||||
|
>
|
||||||
|
<van-tabbar-item icon="home-o">标签</van-tabbar-item>
|
||||||
|
<van-tabbar-item icon="search">标签</van-tabbar-item>
|
||||||
|
<van-tabbar-item icon="friends-o">标签</van-tabbar-item>
|
||||||
|
<van-tabbar-item icon="setting-o">标签</van-tabbar-item>
|
||||||
|
</van-tabbar>
|
||||||
|
```
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
Page({
|
||||||
|
data: {
|
||||||
|
active: 0
|
||||||
|
},
|
||||||
|
// event.detail 的值为当前选中项的索引
|
||||||
|
onChange(event) {
|
||||||
|
console.log(event.detail);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
```
|
||||||
|
|
||||||
### Tabbar API
|
### Tabbar API
|
||||||
|
|
||||||
| 参数 | 说明 | 类型 | 默认值 |
|
| 参数 | 说明 | 类型 | 默认值 |
|
||||||
|-----------|-----------|-----------|-------------|
|
|-----------|-----------|-----------|-------------|
|
||||||
| active | 当前选中标签的索引 | `Number` | - |
|
| active | 当前选中标签的索引 | `Number` | - |
|
||||||
|
| active-color | 选中标签的颜色 | `String` | `#1989fa` |
|
||||||
| fixed | 是否固定在底部 | `Boolean` | `true` |
|
| fixed | 是否固定在底部 | `Boolean` | `true` |
|
||||||
| z-index | 元素 z-index | `Number` | `1` |
|
| z-index | 元素 z-index | `Number` | `1` |
|
||||||
| safe-area-inset-bottom | 是否适配iPhoneX | `Boolean` | `true` |
|
| safe-area-inset-bottom | 是否适配iPhoneX | `Boolean` | `true` |
|
||||||
|
@ -23,6 +23,7 @@ VantComponent({
|
|||||||
|
|
||||||
props: {
|
props: {
|
||||||
active: Number,
|
active: Number,
|
||||||
|
activeColor: String,
|
||||||
fixed: {
|
fixed: {
|
||||||
type: Boolean,
|
type: Boolean,
|
||||||
value: true
|
value: true
|
||||||
@ -52,7 +53,10 @@ VantComponent({
|
|||||||
methods: {
|
methods: {
|
||||||
setActiveItem() {
|
setActiveItem() {
|
||||||
this.data.items.forEach((item, index) => {
|
this.data.items.forEach((item, index) => {
|
||||||
item.setActive(index === this.data.currentActive);
|
item.setActive({
|
||||||
|
active: index === this.data.currentActive,
|
||||||
|
color: this.data.activeColor
|
||||||
|
});
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user