mirror of
https://gitee.com/vant-contrib/vant-weapp.git
synced 2025-04-06 03:58:05 +08:00
[improvement] Tab: optimize code (#899)
This commit is contained in:
parent
d4f303043d
commit
10a76f2982
@ -17,14 +17,12 @@ VantComponent({
|
||||
},
|
||||
|
||||
watch: {
|
||||
disabled() {
|
||||
const parent = this.getRelationNodes('../tabs/index')[0];
|
||||
if (parent) {
|
||||
parent.updateTabs();
|
||||
}
|
||||
},
|
||||
title: 'update',
|
||||
disabled: 'update'
|
||||
},
|
||||
|
||||
title() {
|
||||
methods: {
|
||||
update() {
|
||||
const parent = this.getRelationNodes('../tabs/index')[0];
|
||||
if (parent) {
|
||||
parent.updateTabs();
|
||||
|
@ -10,19 +10,15 @@ VantComponent({
|
||||
name: 'tab',
|
||||
type: 'descendant',
|
||||
linked(child: Weapp.Component) {
|
||||
this.data.tabs.push({
|
||||
instance: child,
|
||||
data: child.data
|
||||
});
|
||||
this.updateTabs();
|
||||
this.child.push(child);
|
||||
this.updateTabs(this.data.tabs.concat(child.data));
|
||||
},
|
||||
unlinked(child: Weapp.Component) {
|
||||
const tabs = this.data.tabs.filter(item => item.instance !== child);
|
||||
this.setData({
|
||||
tabs,
|
||||
scrollable: tabs.length > this.data.swipeThreshold
|
||||
});
|
||||
this.setActiveTab();
|
||||
const index = this.child.indexOf(child);
|
||||
const { tabs } = this.data;
|
||||
tabs.splice(index, 1);
|
||||
this.child.splice(index, 1);
|
||||
this.updateTabs(tabs);
|
||||
}
|
||||
},
|
||||
|
||||
@ -65,7 +61,7 @@ VantComponent({
|
||||
watch: {
|
||||
swipeThreshold() {
|
||||
this.setData({
|
||||
scrollable: this.data.tabs.length > this.data.swipeThreshold
|
||||
scrollable: this.child.length > this.data.swipeThreshold
|
||||
});
|
||||
},
|
||||
color: 'setLine',
|
||||
@ -73,14 +69,18 @@ VantComponent({
|
||||
active: 'setActiveTab'
|
||||
},
|
||||
|
||||
beforeCreate() {
|
||||
this.child = [];
|
||||
},
|
||||
|
||||
mounted() {
|
||||
this.setLine();
|
||||
this.scrollIntoView();
|
||||
},
|
||||
|
||||
methods: {
|
||||
updateTabs() {
|
||||
const { tabs } = this.data;
|
||||
updateTabs(tabs) {
|
||||
tabs = tabs || this.data.tabs;
|
||||
this.setData({
|
||||
tabs,
|
||||
scrollable: tabs.length > this.data.swipeThreshold
|
||||
@ -91,13 +91,13 @@ VantComponent({
|
||||
trigger(eventName: string, index: number) {
|
||||
this.$emit(eventName, {
|
||||
index,
|
||||
title: this.data.tabs[index].data.title
|
||||
title: this.data.tabs[index].title
|
||||
});
|
||||
},
|
||||
|
||||
onTap(event: Weapp.Event) {
|
||||
const { index } = event.currentTarget.dataset;
|
||||
if (this.data.tabs[index].data.disabled) {
|
||||
if (this.data.tabs[index].disabled) {
|
||||
this.trigger('disabled', index);
|
||||
} else {
|
||||
this.trigger('click', index);
|
||||
@ -138,7 +138,7 @@ VantComponent({
|
||||
},
|
||||
|
||||
setActiveTab() {
|
||||
this.data.tabs.forEach((item, index) => {
|
||||
this.child.forEach((item, index) => {
|
||||
const data: TabItemData = {
|
||||
active: index === this.data.active
|
||||
};
|
||||
@ -147,8 +147,8 @@ VantComponent({
|
||||
data.inited = true;
|
||||
}
|
||||
|
||||
if (data.active !== item.instance.data.active) {
|
||||
item.instance.setData(data);
|
||||
if (data.active !== item.data.active) {
|
||||
item.setData(data);
|
||||
}
|
||||
});
|
||||
|
||||
|
@ -13,11 +13,11 @@
|
||||
wx:for="{{ tabs }}"
|
||||
wx:key="index"
|
||||
data-index="{{ index }}"
|
||||
class="van-ellipsis van-tab {{ index === active ? 'van-tab--active' : '' }} {{ item.data.disabled ? 'van-tab--disabled' : '' }}"
|
||||
style="{{ color && (index === active) !== (type === 'card') && !item.data.disabled ? 'color: ' + color : '' }} {{ color && index === active && type === 'card' ? ';background-color:' + color : '' }} {{ color ? ';border-color: ' + color : '' }}"
|
||||
class="van-ellipsis van-tab {{ index === active ? 'van-tab--active' : '' }} {{ item.disabled ? 'van-tab--disabled' : '' }}"
|
||||
style="{{ color && (index === active) !== (type === 'card') && !item.disabled ? 'color: ' + color : '' }} {{ color && index === active && type === 'card' ? ';background-color:' + color : '' }} {{ color ? ';border-color: ' + color : '' }}"
|
||||
bind:tap="onTap"
|
||||
>
|
||||
{{ item.data.title }}
|
||||
{{ item.title }}
|
||||
</view>
|
||||
</view>
|
||||
</scroll-view>
|
||||
|
Loading…
x
Reference in New Issue
Block a user