mirror of
https://gitee.com/vant-contrib/vant-weapp.git
synced 2025-04-06 03:58:05 +08:00
perf(picker): use wxs (#3949)
This commit is contained in:
parent
e2dbe4d9fc
commit
5726819a78
@ -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>
|
||||||
|
@ -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,
|
||||||
|
};
|
||||||
|
@ -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: {
|
||||||
|
@ -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
42
packages/picker/index.wxs
Normal 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,
|
||||||
|
};
|
Loading…
x
Reference in New Issue
Block a user