perf(picker): use wxs (#3949)

This commit is contained in:
rex 2021-01-08 16:28:22 +08:00 committed by GitHub
parent e2dbe4d9fc
commit 5726819a78
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 91 additions and 23 deletions

View File

@ -1,22 +1,23 @@
<wxs src="./index.wxs" module="getOptionText" /> <wxs src="../wxs/utils.wxs" module="utils" />
<wxs src="./index.wxs" module="computed" />
<view <view
class="van-picker-column custom-class" class="van-picker-column custom-class"
style="height: {{ itemHeight * visibleItemCount }}px" style="{{ computed.rootStyle({ itemHeight, visibleItemCount }) }}"
bind:touchstart="onTouchStart" bind:touchstart="onTouchStart"
catch:touchmove="onTouchMove" catch:touchmove="onTouchMove"
bind:touchend="onTouchEnd" bind:touchend="onTouchEnd"
bind:touchcancel="onTouchEnd" bind:touchcancel="onTouchEnd"
> >
<view style="transition: transform {{ duration }}ms; line-height: {{ itemHeight }}px; transform: translate3d(0, {{ offset + (itemHeight * (visibleItemCount - 1)) / 2 }}px, 0)"> <view style="{{ computed.wrapperStyle({ offset, itemHeight, visibleItemCount }) }}">
<view <view
wx:for="{{ options }}" wx:for="{{ options }}"
wx:for-item="option" wx:for-item="option"
wx:key="index" wx:key="index"
data-index="{{ index }}" data-index="{{ index }}"
style="height: {{ itemHeight }}px" style="height: {{ itemHeight }}px"
class="van-ellipsis van-picker-column__item {{ option && option.disabled ? 'van-picker-column__item--disabled' : '' }} {{ index === currentIndex ? 'van-picker-column__item--selected active-class' : '' }}" class="van-ellipsis {{ utils.bem('picker-column__item', { disabled: option && option.disabled, selected: index === currentIndex }) }} {{ index === currentIndex ? 'active-class' : '' }}"
bindtap="onClickItem" bindtap="onClickItem"
>{{ getOptionText(option, valueKey) }}</view> >{{ computed.optionText(option, valueKey) }}</view>
</view> </view>
</view> </view>

View File

@ -1,8 +1,36 @@
/* eslint-disable */
var style = require('../wxs/style.wxs');
var addUnit = require('../wxs/add-unit.wxs');
function isObj(x) { function isObj(x) {
var type = typeof x; var type = typeof x;
return x !== null && (type === 'object' || type === 'function'); return x !== null && (type === 'object' || type === 'function');
} }
module.exports = function (option, valueKey) { function optionText(option, valueKey) {
return isObj(option) && option[valueKey] != null ? option[valueKey] : option; return isObj(option) && option[valueKey] != null ? option[valueKey] : option;
} }
function rootStyle(data) {
return style({
height: addUnit(data.itemHeight * data.visibleItemCount),
});
}
function wrapperStyle(data) {
var offset = addUnit(
data.offset + (data.itemHeight * (data.visibleItemCount - 1)) / 2
);
return style({
transition: 'transform ' + data.duration + 'ms',
'line-height': addUnit(data.itemHeight),
transform: 'translate3d(0, ' + offset + ', 0)',
});
}
module.exports = {
optionText: optionText,
rootStyle: rootStyle,
wrapperStyle: wrapperStyle,
};

View File

@ -28,7 +28,6 @@ VantComponent({
value: [], value: [],
observer(columns = []) { observer(columns = []) {
this.simple = columns.length && !columns[0].values; this.simple = columns.length && !columns[0].values;
this.children = this.selectAllComponents('.van-picker__column');
if (Array.isArray(this.children) && this.children.length) { if (Array.isArray(this.children) && this.children.length) {
this.setColumns().catch(() => {}); this.setColumns().catch(() => {});
@ -38,7 +37,9 @@ VantComponent({
}, },
beforeCreate() { beforeCreate() {
this.children = []; Object.defineProperty(this, 'children', {
get: () => this.selectAllComponents('.van-picker__column') || [],
});
}, },
methods: { methods: {

View File

@ -1,41 +1,37 @@
<import src="./toolbar.wxml" /> <wxs src="./index.wxs" module="computed" />
<view class="van-picker custom-class"> <view class="van-picker custom-class">
<template is="toolbar" wx:if="{{ toolbarPosition === 'top' }}" data="{{ showToolbar, cancelButtonText, title, confirmButtonText }}"></template> <include wx:if="{{ toolbarPosition === 'top' }}" src="toolbar.wxml" />
<view wx:if="{{ loading }}" class="van-picker__loading"> <view wx:if="{{ loading }}" class="van-picker__loading">
<loading color="#1989fa"/> <loading color="#1989fa"/>
</view> </view>
<view <view
class="van-picker__columns" class="van-picker__columns"
style="height: {{ itemHeight * visibleItemCount }}px" style="{{ computed.columnsStyle({ itemHeight, visibleItemCount }) }}"
catch:touchmove="noop" catch:touchmove="noop"
> >
<picker-column <picker-column
class="van-picker__column" class="van-picker__column"
wx:for="{{ isSimple(columns) ? [columns] : columns }}" wx:for="{{ computed.columns(columns) }}"
wx:key="index" wx:key="index"
data-index="{{ index }}" data-index="{{ index }}"
custom-class="column-class" custom-class="column-class"
value-key="{{ valueKey }}" value-key="{{ valueKey }}"
initial-options="{{ isSimple(columns) ? item : item.values }}" initial-options="{{ item.values }}"
default-index="{{ item.defaultIndex || defaultIndex }}" default-index="{{ item.defaultIndex || defaultIndex }}"
item-height="{{ itemHeight }}" item-height="{{ itemHeight }}"
visible-item-count="{{ visibleItemCount }}" visible-item-count="{{ visibleItemCount }}"
active-class="active-class" active-class="active-class"
bind:change="onChange" bind:change="onChange"
/> />
<view class="van-picker__mask" style="background-size: 100% {{ (itemHeight * visibleItemCount - itemHeight) / 2 }}px" /> <view class="van-picker__mask" style="{{ computed.maskStyle({ itemHeight, visibleItemCount }) }}" />
<view <view
class="van-picker__frame van-hairline--top-bottom" class="van-picker__frame van-hairline--top-bottom"
style="height: {{ itemHeight }}px" style="{{ computed.frameStyle({ itemHeight }) }}"
/> />
</view> </view>
<template is="toolbar" wx:if="{{ toolbarPosition === 'bottom' }}" data="{{ showToolbar, cancelButtonText, title, confirmButtonText }}"></template>
</view>
<wxs module="isSimple"> <include wx:if="{{ toolbarPosition === 'bottom' }}" src="toolbar.wxml" />
function isSimple(columns) { </view>
return columns.length && !columns[0].values;
}
module.exports = isSimple;
</wxs>

42
packages/picker/index.wxs Normal file
View File

@ -0,0 +1,42 @@
/* eslint-disable */
var style = require('../wxs/style.wxs');
var addUnit = require('../wxs/add-unit.wxs');
var array = require('../wxs/array.wxs');
function columnsStyle(data) {
return style({
height: addUnit(data.itemHeight * data.visibleItemCount),
});
}
function maskStyle(data) {
return style({
'background-size':
'100% ' + addUnit((data.itemHeight * (data.visibleItemCount - 1)) / 2),
});
}
function frameStyle(data) {
return style({
height: addUnit(data.itemHeight),
});
}
function columns(columns) {
if (!array.isArray(columns)) {
return [];
}
if (columns.length && !columns[0].values) {
return [{ values: columns }];
}
return columns;
}
module.exports = {
columnsStyle: columnsStyle,
frameStyle: frameStyle,
maskStyle: maskStyle,
columns: columns,
};