| ¶Ô±ÈÐÂÎļþ |
| | |
| | | /** |
| | | * 使ç¨wxsæ¹æ¡å®ç°slider |
| | | * å
¼å®¹å¾®ä¿¡ï¼QQï¼H5ï¼Vueççå®ååiOS |
| | | */ |
| | | /** |
| | | * å¼å§æ»å¨æä½ |
| | | * @param {Object} e |
| | | * @param {Object} ownerInstance |
| | | */ |
| | | function onTouchMove(e, ownerInstance) { |
| | | // wxsäºä»¶å¯¹è±¡ä¸æä¸ä¸ªinstance屿§ï¼è¡¨ç¤ºå½åè§¦åæ¤äºä»¶çç»ä»¶çå®ä¾ï¼éè¿è¯¥å®ä¾ï¼å¯ä»¥è·åç¸å
³çdatasetï¼è®¾ç½®æ ·å¼çä¿¡æ¯ |
| | | // https://developers.weixin.qq.com/miniprogram/dev/framework/view/interactive-animation.html |
| | | var instance = e.instance; |
| | | // getState()为ä¸ä¸ªå¯¹è±¡ï¼æè½½å¨instanceä¸ï¼ç±»ä¼¼ç»ä»¶çdata䏿 ·ï¼å¯ä»¥åæ¾ä¸äºåéï¼ä¾ä»¥åç触åäºä»¶ä¸ä½¿ç¨ |
| | | var state = instance.getState() |
| | | |
| | | // æ»åç»ä»¶çæ´ä½å°ºå¯¸ä¿¡æ¯ |
| | | var mp = state.mp |
| | | if(mp.disabled) { |
| | | return |
| | | } |
| | | |
| | | var distanceX = getTouchX(e) - mp.left |
| | | // è·å¾ç§»å¨è·ç¦»å¯¹æ´ä¸ªæ»åçç¾åæ¯å¼ï¼æ¤ä¸ºå¸¦æå¤ä½å°æ°çå¼ï¼step大äº1æ¶ï¼ä¸è½ç¨æ¤æ´æ°è§å¾ |
| | | var percent = (distanceX / mp.width) * 100 |
| | | |
| | | updateSliderPlacement(instance, ownerInstance, percent, 'moving') |
| | | |
| | | // 黿¢é¡µé¢æ»å¨ï¼å¯ä»¥ä¿è¯å¨æ»å¨è¿ç¨ä¸ï¼ä¸è®©é¡µé¢å¯ä»¥ä¸ä¸æ»å¨ï¼é æä¸å¥½çä½éª |
| | | e.stopPropagation && e.stopPropagation() |
| | | e.preventDefault && e.preventDefault() |
| | | } |
| | | |
| | | function onClick(e, ownerInstance) { |
| | | var instance = e.instance |
| | | var state = instance.getState() |
| | | var mp = state.mp |
| | | if(mp.disabled) { |
| | | return |
| | | } |
| | | |
| | | // ç´æ¥ç¹å»æ»åçæ
åµï¼è®¡ç®æ¹å¼ä¸onTouchMoveæ¹æ³ç¸å |
| | | var value = ((e.detail.x - mp.left) / mp.width) * 100 |
| | | updateSliderPlacement(instance, ownerInstance, value, 'click') |
| | | } |
| | | |
| | | function sizeReady(newValue, oldValue, ownerInstance, instance) { |
| | | // 页é¢åå§åæ¶åï¼ä¹ä¼è§¦åæ¤æ¹æ³ï¼ä¼ éçå¼ä¸ºç©ºï¼è¿é䏿§è¡å¾åçé»è¾ |
| | | if(!newValue || newValue.disabled) { |
| | | return |
| | | } |
| | | var state = instance.getState() |
| | | state.mp = newValue |
| | | updateSliderPlacement(instance, ownerInstance, newValue.value) |
| | | } |
| | | |
| | | // 设置æ»ç¹çä½ç½® |
| | | function updateSliderPlacement(instance, ownerInstance, value, event) { |
| | | var state = instance.getState() |
| | | var mp = state.mp |
| | | if(mp.disabled) { |
| | | return |
| | | } |
| | | |
| | | var percent = 0 |
| | | if (mp.step > 1) { |
| | | // 妿stepæ¥è¿å¤§äº1ï¼éè¦è·³æ¥ï¼æä»¥éè¦ä½¿ç¨Math.roundè¿è¡åæ´ |
| | | percent = Math.round(Math.max(mp.min, Math.min(value, mp.max)) / mp.step) * mp.step |
| | | } else { |
| | | // å½step=1æ¶ï¼æ éè·³æ¥ï¼å
åå©ç¨wxsæ§è½ï¼æ»å宿¶è·éæå¿ï¼è¾¾å°ä¸æ»çææ |
| | | percent = Math.max(mp.min, Math.min(value, mp.max)) |
| | | } |
| | | // è¿åç»ä»¶çå®ä¾ |
| | | var gapInstance = ownerInstance.selectComponent('.u-slider__gap') |
| | | // å¨ç§»å¨æé´ï¼ä¸å
许transitionå¨ç»ï¼å¦åä¼é æå¡é¡¿ |
| | | gapInstance[event === 'click' ? 'addClass' : 'removeClass']('u-slider__gap--ani') |
| | | // è°ç¨é»è¾å±çæ¹æ³ï¼ä¿®æ¹v-modelç»å®çå¼ |
| | | ownerInstance.callMethod('updateValue', Math.round(percent)) |
| | | if(event) { |
| | | ownerInstance.callMethod('emitEvent', { |
| | | event: event, |
| | | value: Math.round(percent) |
| | | }) |
| | | } |
| | | |
| | | // 设置移å¨çå¼ |
| | | gapInstance.requestAnimationFrame(function() { |
| | | gapInstance.setStyle({ |
| | | width: percent / 100 * mp.width + 'px', |
| | | }) |
| | | }) |
| | | } |
| | | |
| | | // å¼å§æ»å¨ |
| | | function onTouchStart(e, ownerInstance) { |
| | | ownerInstance.callMethod('emitEvent', { |
| | | event: 'start', |
| | | value: null |
| | | }) |
| | | } |
| | | |
| | | // 忢æ»å¨ |
| | | function onTouchEnd(e, ownerInstance) { |
| | | ownerInstance.callMethod('emitEvent', { |
| | | event: 'end', |
| | | value: null |
| | | }) |
| | | } |
| | | |
| | | // è·åå½åæå¿ç¹çXè½´ä½ç§»å¼ |
| | | function getTouchX(e) { |
| | | return e.touches[0].clientX |
| | | } |
| | | |
| | | module.exports = { |
| | | onTouchStart: onTouchStart, |
| | | onTouchMove: onTouchMove, |
| | | onTouchEnd: onTouchEnd, |
| | | sizeReady: sizeReady, |
| | | onClick: onClick |
| | | } |