mirror of
https://gitee.com/vant-contrib/vant-weapp.git
synced 2025-04-06 03:58:05 +08:00
83 lines
1.5 KiB
TypeScript
83 lines
1.5 KiB
TypeScript
import { getRect } from '../common/utils';
|
|
import { VantComponent } from '../common/component';
|
|
|
|
type TrivialInstance = WechatMiniprogram.Component.TrivialInstance;
|
|
|
|
VantComponent({
|
|
relation: {
|
|
name: 'tabbar-item',
|
|
type: 'descendant',
|
|
current: 'tabbar',
|
|
linked(target) {
|
|
target.parent = this;
|
|
target.updateFromParent();
|
|
},
|
|
unlinked() {
|
|
this.updateChildren();
|
|
},
|
|
},
|
|
|
|
props: {
|
|
active: {
|
|
type: null,
|
|
observer: 'updateChildren',
|
|
},
|
|
activeColor: {
|
|
type: String,
|
|
observer: 'updateChildren',
|
|
},
|
|
inactiveColor: {
|
|
type: String,
|
|
observer: 'updateChildren',
|
|
},
|
|
fixed: {
|
|
type: Boolean,
|
|
value: true,
|
|
observer: 'setHeight',
|
|
},
|
|
placeholder: {
|
|
type: Boolean,
|
|
observer: 'setHeight',
|
|
},
|
|
border: {
|
|
type: Boolean,
|
|
value: true,
|
|
},
|
|
zIndex: {
|
|
type: Number,
|
|
value: 1,
|
|
},
|
|
safeAreaInsetBottom: {
|
|
type: Boolean,
|
|
value: true,
|
|
},
|
|
},
|
|
|
|
data: {
|
|
height: 50,
|
|
},
|
|
|
|
methods: {
|
|
updateChildren() {
|
|
const { children } = this;
|
|
if (!Array.isArray(children) || !children.length) {
|
|
return;
|
|
}
|
|
|
|
children.forEach((child: TrivialInstance) => child.updateFromParent());
|
|
},
|
|
|
|
setHeight() {
|
|
if (!this.data.fixed || !this.data.placeholder) {
|
|
return;
|
|
}
|
|
|
|
wx.nextTick(() => {
|
|
getRect.call(this, '.van-tabbar').then((res) => {
|
|
this.setData({ height: res.height });
|
|
});
|
|
});
|
|
},
|
|
},
|
|
});
|