feat(Tab): add new prop ellipsis & improve performance (#2334)

fix #1605, fix #2297
This commit is contained in:
rex 2019-11-19 11:50:50 +08:00 committed by GitHub
parent 60453083b3
commit 7d7cfd12b3
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 73 additions and 11 deletions

View File

@ -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
}); });
}, },

View File

@ -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>

View File

@ -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;

View File

@ -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

View File

@ -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
View 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;