mirror of
https://gitee.com/vant-contrib/vant-weapp.git
synced 2025-04-06 03:58:05 +08:00
feat(Tab): add new prop ellipsis & improve performance (#2334)
fix #1605, fix #2297
This commit is contained in:
parent
60453083b3
commit
7d7cfd12b3
@ -50,8 +50,7 @@ VantComponent({
|
|||||||
this.inited = this.inited || active;
|
this.inited = this.inited || active;
|
||||||
this.setData({
|
this.setData({
|
||||||
active,
|
active,
|
||||||
shouldRender: this.inited || !parentData.lazyRender,
|
shouldRender: this.inited || !parentData.lazyRender
|
||||||
shouldShow: active || parentData.animated
|
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -3,7 +3,6 @@
|
|||||||
<view
|
<view
|
||||||
wx:if="{{ shouldRender }}"
|
wx:if="{{ shouldRender }}"
|
||||||
class="custom-class {{ utils.bem('tab__pane', { active, inactive: !active }) }}"
|
class="custom-class {{ utils.bem('tab__pane', { active, inactive: !active }) }}"
|
||||||
style="{{ shouldShow ? '' : 'display: none;' }}"
|
|
||||||
>
|
>
|
||||||
<slot />
|
<slot />
|
||||||
</view>
|
</view>
|
||||||
|
@ -117,6 +117,10 @@
|
|||||||
.theme(color, '@tab-disabled-text-color');
|
.theme(color, '@tab-disabled-text-color');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
&--complete {
|
||||||
|
flex: 1 0 auto !important;
|
||||||
|
}
|
||||||
|
|
||||||
&__title {
|
&__title {
|
||||||
&__info {
|
&__info {
|
||||||
position: relative !important;
|
position: relative !important;
|
||||||
|
@ -50,6 +50,8 @@ VantComponent({
|
|||||||
value: -1,
|
value: -1,
|
||||||
observer: 'setLine'
|
observer: 'setLine'
|
||||||
},
|
},
|
||||||
|
titleActiveColor: String,
|
||||||
|
titleInactiveColor: String,
|
||||||
active: {
|
active: {
|
||||||
type: [String, Number],
|
type: [String, Number],
|
||||||
value: 0,
|
value: 0,
|
||||||
@ -84,7 +86,7 @@ VantComponent({
|
|||||||
value: 4,
|
value: 4,
|
||||||
observer(value) {
|
observer(value) {
|
||||||
this.setData({
|
this.setData({
|
||||||
scrollable: this.children.length > value
|
scrollable: this.children.length > value || !this.data.ellipsis
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
@ -126,7 +128,7 @@ VantComponent({
|
|||||||
const { children = [], data } = this;
|
const { children = [], data } = this;
|
||||||
this.setData({
|
this.setData({
|
||||||
tabs: children.map((child: TrivialInstance) => child.data),
|
tabs: children.map((child: TrivialInstance) => child.data),
|
||||||
scrollable: children.length > data.swipeThreshold
|
scrollable: this.children.length > data.swipeThreshold || !data.ellipsis
|
||||||
});
|
});
|
||||||
|
|
||||||
this.setCurrentIndexByName(this.getCurrentName() || data.active);
|
this.setCurrentIndexByName(this.getCurrentName() || data.active);
|
||||||
@ -173,7 +175,6 @@ VantComponent({
|
|||||||
|
|
||||||
if (
|
if (
|
||||||
!isDef(currentIndex) ||
|
!isDef(currentIndex) ||
|
||||||
currentIndex === data.currentIndex ||
|
|
||||||
currentIndex >= children.length ||
|
currentIndex >= children.length ||
|
||||||
currentIndex < 0
|
currentIndex < 0
|
||||||
) {
|
) {
|
||||||
@ -185,7 +186,7 @@ VantComponent({
|
|||||||
|
|
||||||
children.forEach((item: TrivialInstance, index: number) => {
|
children.forEach((item: TrivialInstance, index: number) => {
|
||||||
const active = index === currentIndex;
|
const active = index === currentIndex;
|
||||||
if (active !== item.data.active) {
|
if (active !== item.data.active || !item.inited) {
|
||||||
item.updateRender(active, this);
|
item.updateRender(active, this);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -224,8 +225,11 @@ VantComponent({
|
|||||||
} = this.data;
|
} = this.data;
|
||||||
|
|
||||||
this.getRect('.van-tab', true).then(
|
this.getRect('.van-tab', true).then(
|
||||||
(rects: WechatMiniprogram.BoundingClientRectCallbackResult[]) => {
|
(rects: WechatMiniprogram.BoundingClientRectCallbackResult[] = []) => {
|
||||||
const rect = rects[currentIndex];
|
const rect = rects[currentIndex];
|
||||||
|
if (rect == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
const width = lineWidth !== -1 ? lineWidth : rect.width / 2;
|
const width = lineWidth !== -1 ? lineWidth : rect.width / 2;
|
||||||
const height =
|
const height =
|
||||||
lineHeight !== -1
|
lineHeight !== -1
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
<wxs src="../wxs/utils.wxs" module="utils" />
|
<wxs src="../wxs/utils.wxs" module="utils" />
|
||||||
|
<wxs src="./index.wxs" module="getters" />
|
||||||
|
|
||||||
<view class="custom-class {{ utils.bem('tabs', [type]) }}">
|
<view class="custom-class {{ utils.bem('tabs', [type]) }}">
|
||||||
<van-sticky
|
<van-sticky
|
||||||
@ -24,11 +25,11 @@
|
|||||||
wx:for="{{ tabs }}"
|
wx:for="{{ tabs }}"
|
||||||
wx:key="index"
|
wx:key="index"
|
||||||
data-index="{{ index }}"
|
data-index="{{ index }}"
|
||||||
class="van-ellipsis tab-class {{ index === currentIndex ? 'tab-active-class' : '' }} {{ utils.bem('tab', { active: index === currentIndex, disabled: item.disabled }) }}"
|
class="{{ getters.tabClass(index === currentIndex, ellipsis) }} {{ utils.bem('tab', { active: index === currentIndex, disabled: item.disabled, complete: !ellipsis }) }}"
|
||||||
style="{{ color && index !== currentIndex && type === 'card' && !item.disabled ? 'color: ' + color : '' }} {{ color && index === currentIndex && type === 'card' ? ';background-color:' + color : '' }} {{ color ? ';border-color: ' + color : '' }} {{ scrollable ? ';flex-basis:' + (88 / swipeThreshold) + '%' : '' }}"
|
style="{{ getters.tabStyle(index === currentIndex, ellipsis, color, type, item.disabled, titleActiveColor, titleInactiveColor, swipeThreshold, scrollable) }}"
|
||||||
bind:tap="onTap"
|
bind:tap="onTap"
|
||||||
>
|
>
|
||||||
<view class="van-ellipsis" style="{{ item.titleStyle }}">
|
<view class="{{ ellipsis ? 'van-ellipsis' : '' }}" style="{{ item.titleStyle }}">
|
||||||
{{ item.title }}
|
{{ item.title }}
|
||||||
<van-info
|
<van-info
|
||||||
wx:if="{{ item.info !== null || item.dot }}"
|
wx:if="{{ item.info !== null || item.dot }}"
|
||||||
|
55
packages/tabs/index.wxs
Normal file
55
packages/tabs/index.wxs
Normal file
@ -0,0 +1,55 @@
|
|||||||
|
/* eslint-disable */
|
||||||
|
function tabClass(active, ellipsis) {
|
||||||
|
var classes = ['tab-class'];
|
||||||
|
|
||||||
|
if (active) {
|
||||||
|
classes.push('tab-active-class');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ellipsis) {
|
||||||
|
classes.push('van-ellipsis');
|
||||||
|
}
|
||||||
|
|
||||||
|
return classes.join(' ');
|
||||||
|
}
|
||||||
|
|
||||||
|
function tabStyle(
|
||||||
|
active,
|
||||||
|
ellipsis,
|
||||||
|
color,
|
||||||
|
type,
|
||||||
|
disabled,
|
||||||
|
activeColor,
|
||||||
|
inactiveColor,
|
||||||
|
swipeThreshold,
|
||||||
|
scrollable
|
||||||
|
) {
|
||||||
|
var styles = [];
|
||||||
|
var isCard = type === 'card';
|
||||||
|
// card theme color
|
||||||
|
if (color && isCard) {
|
||||||
|
styles.push('border-color:' + color);
|
||||||
|
|
||||||
|
if (!disabled) {
|
||||||
|
if (active) {
|
||||||
|
styles.push('background-color:' + color);
|
||||||
|
} else {
|
||||||
|
styles.push('color:' + color);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var titleColor = active ? activeColor : inactiveColor;
|
||||||
|
if (titleColor) {
|
||||||
|
styles.push('color:' + titleColor);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (scrollable && ellipsis) {
|
||||||
|
styles.push('flex-basis:' + 88 / swipeThreshold + '%');
|
||||||
|
}
|
||||||
|
|
||||||
|
return styles.join(';');
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports.tabClass = tabClass;
|
||||||
|
module.exports.tabStyle = tabStyle;
|
Loading…
x
Reference in New Issue
Block a user