榆山
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

35 lines
2.1 KiB

<view class="wux-class {{ classes.wrap }}" style="{{ extWrapStyle }}">
<view class="{{ classes.min }}" wx:if="{{ common.getValue(showValue, 'min') }}">{{ min }}</view>
<slot name="min" wx:else></slot>
<view class="{{ classes.rail }}" style="{{ extRailStyle }}">
<block wx:for="{{ marks }}" wx:key="" wx:if="{{ showMark && marks.length > 0 }}">
<view class="{{ classes.mark }}" style="left: {{ item + '%' }}; {{ common.getStyle(extMarkStyle, index) }}" />
</block>
<block wx:for="{{ inputValue }}" wx:key="">
<view
class="{{ classes.track }}"
style="{{ common.getTrackStyle(offsets, index, inputValue.length > 1) }}; {{ common.getStyle(extTrackStyle, index) }}"
wx:if="{{ inputValue.length === 1 || index !== inputValue.length - 1 }}"
/>
<view
class="{{ classes.handle }} {{ last === index ? prefixCls + '__handle--last' : '' }} {{ last === index && isTouched ? prefixCls + '__handle--is-touched' : '' }}"
data-index="{{ index }}"
data-meta="{{ common.format(tipFormatter, item) }}"
bindtouchstart="onTouchStart"
catchtouchmove="{{ isMoved ? 'noop' : '' }}"
capture-bind:touchmove="onTouchMove"
bindtouchend="onTouchEnd"
style="left: {{ offsets[index] + '%' }}; {{ common.getStyle(extHandleStyle, index) }}"
/>
</block>
</view>
<view class="{{ classes.max }}" wx:if="{{ common.getValue(showValue, 'max') }}">{{ max }}</view>
<slot name="max" wx:else></slot>
</view>
<wxs module="common">
module.exports.format = function(source, value) { return source.replace(getRegExp('\{d\}', 'g'), value) }
module.exports.getTrackStyle = function(offsets, index, multiple) { if (!multiple) { return 'width: ' + offsets[index] + '%' } return 'left: ' + offsets[index] + '%; width: ' + (offsets[index + 1] - offsets[index]) + '%' }
module.exports.getStyle = function(style, index) { if (style.constructor !== 'String') { return style[index] } return style }
module.exports.getValue = function(obj, name) { if (obj.constructor === 'Object') { return obj[name] } return obj }
</wxs>