mirror of
https://gitee.com/vant-contrib/vant-weapp.git
synced 2025-04-06 03:58:05 +08:00
parent
cdc27120a5
commit
d99829d28d
@ -9,7 +9,10 @@ VantComponent({
|
|||||||
|
|
||||||
relation: {
|
relation: {
|
||||||
name: 'tabbar',
|
name: 'tabbar',
|
||||||
type: 'ancestor'
|
type: 'ancestor',
|
||||||
|
linked(target: Weapp.Component) {
|
||||||
|
this.parent = target;
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
data: {
|
data: {
|
||||||
@ -18,17 +21,17 @@ VantComponent({
|
|||||||
|
|
||||||
methods: {
|
methods: {
|
||||||
onClick() {
|
onClick() {
|
||||||
const parent = this.getRelationNodes('../tabbar/index')[0];
|
if (this.parent) {
|
||||||
if (parent) {
|
this.parent.onChange(this);
|
||||||
parent.onChange(this);
|
|
||||||
}
|
}
|
||||||
this.$emit('click');
|
this.$emit('click');
|
||||||
},
|
},
|
||||||
|
|
||||||
setActive({ active, color }) {
|
setActive({ active, color }): Promise<void> {
|
||||||
if (this.data.active !== active) {
|
if (this.data.active !== active) {
|
||||||
this.set({ active, color });
|
return this.set({ active, color });
|
||||||
}
|
}
|
||||||
|
return Promise.resolve();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -1,9 +1,11 @@
|
|||||||
|
<wxs src="../wxs/utils.wxs" module="utils" />
|
||||||
|
|
||||||
<view
|
<view
|
||||||
class="van-tabbar-item custom-class {{ active ? 'van-tabbar-item--active' : '' }}"
|
class="{{ utils.bem('tabbar-item', { active }) }} custom-class"
|
||||||
style="{{ active && color ? 'color: ' + color : '' }}"
|
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="{{ utils.bem('tabbar-item__icon', { dot }) }}">
|
||||||
<van-icon
|
<van-icon
|
||||||
wx:if="{{ icon }}"
|
wx:if="{{ icon }}"
|
||||||
name="{{ icon }}"
|
name="{{ icon }}"
|
||||||
|
@ -131,10 +131,3 @@ Page({
|
|||||||
|-----------|-----------|
|
|-----------|-----------|
|
||||||
| icon | 未选中时的图标 |
|
| icon | 未选中时的图标 |
|
||||||
| icon-active | 选中时的图标 |
|
| icon-active | 选中时的图标 |
|
||||||
|
|
||||||
### 更新日志
|
|
||||||
|
|
||||||
| 版本 | 类型 | 内容 |
|
|
||||||
|-----------|-----------|-----------|
|
|
||||||
| 0.1.1 | feature | 新增组件 |
|
|
||||||
| 0.2.1 | bugfix | 修复 z-index 不生效的问题 |
|
|
||||||
|
@ -8,16 +8,14 @@ VantComponent({
|
|||||||
name: 'tabbar-item',
|
name: 'tabbar-item',
|
||||||
type: 'descendant',
|
type: 'descendant',
|
||||||
linked(target: Weapp.Component) {
|
linked(target: Weapp.Component) {
|
||||||
this.data.items.push(target);
|
this.children = this.children || [];
|
||||||
setTimeout(() => {
|
this.children.push(target);
|
||||||
this.setActiveItem();
|
this.setActiveItem();
|
||||||
});
|
|
||||||
},
|
},
|
||||||
unlinked(target: Weapp.Component) {
|
unlinked(target: Weapp.Component) {
|
||||||
this.data.items = this.data.items.filter(item => item !== target);
|
this.children = this.children || [];
|
||||||
setTimeout(() => {
|
this.children = this.children.filter(item => item !== target);
|
||||||
this.setActiveItem();
|
this.setActiveItem();
|
||||||
});
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -34,12 +32,8 @@ VantComponent({
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
data: {
|
|
||||||
items: []
|
|
||||||
},
|
|
||||||
|
|
||||||
watch: {
|
watch: {
|
||||||
active(active) {
|
active(active: number) {
|
||||||
this.currentActive = active;
|
this.currentActive = active;
|
||||||
this.setActiveItem();
|
this.setActiveItem();
|
||||||
}
|
}
|
||||||
@ -50,21 +44,28 @@ VantComponent({
|
|||||||
},
|
},
|
||||||
|
|
||||||
methods: {
|
methods: {
|
||||||
setActiveItem() {
|
setActiveItem(): Promise<any> {
|
||||||
this.data.items.forEach((item, index) => {
|
if (!Array.isArray(this.children) || !this.children.length) {
|
||||||
item.setActive({
|
return Promise.resolve();
|
||||||
active: index === this.currentActive,
|
}
|
||||||
color: this.data.activeColor
|
return Promise.all(
|
||||||
});
|
this.children.map((item: Weapp.Component, index: number) =>
|
||||||
});
|
item.setActive({
|
||||||
|
active: index === this.currentActive,
|
||||||
|
color: this.data.activeColor
|
||||||
|
})
|
||||||
|
)
|
||||||
|
);
|
||||||
},
|
},
|
||||||
|
|
||||||
onChange(child) {
|
onChange(child: Weapp.Component) {
|
||||||
const active = this.data.items.indexOf(child);
|
const active = (this.children || []).indexOf(child);
|
||||||
|
|
||||||
if (active !== this.currentActive && active !== -1) {
|
if (active !== this.currentActive && active !== -1) {
|
||||||
this.$emit('change', active);
|
|
||||||
this.currentActive = active;
|
this.currentActive = active;
|
||||||
this.setActiveItem();
|
this.setActiveItem().then(() => {
|
||||||
|
this.$emit('change', active);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user