之前在做一個手機端項目的時候,需要一個左右滑動(按周滑動)選擇日期插件,而且當時這個項目沒有用到Vue。當時又沒有找到合適的第三方插件,就花了點時間用原生JavaScript寫了出來,當時心中就想把它寫成基于Vue的組件,這短時間閑了把它弄出來了!,在這個過程中遇到了一個坑,后面會提出來!
先看效果
思路
根據用戶傳入日期(不傳默認今天),獲取上一周,當周,下一周對應的日期放數組dates里
let vm = this this.dates.push( { date: moment(vm.defaultDate).subtract(7, 'd').format('YYYY-MM-DD'), }, { date: vm.defaultDate, }, { date: moment(vm.defaultDate).add(7, 'd').format('YYYY-MM-DD'), } )
根據datas 生成每一周對應的日期
getDaies (date) { let vm = this, arr = [] let weekOfDate = Number(moment(date).format('E')) let weeks = ['日', '一', '二', '三', '四', '五', '六'] let today = moment() let defaultDay = moment(vm.defaultDate) for (var i = 0; i < 7; i++) { let _theDate = moment(date).subtract(weekOfDate - i, 'd') arr.push({ date: _theDate.format('YYYY-MM-DD'), week: weeks[i], isToday: _theDate.format('YYYY-MM-DD') === today.format('YYYY-MM-DD'), isDay: _theDate.format('E') === defaultDay.format('E') }) } return arr }
生成每一個滑動單元的style
getTransform (index) { let vm = this let style = {} if (index === vm.activeIndex) { style['transform'] = 'translateX('+ vm.distan.x +'px)' } if (index < vm.activeIndex) { style['transform'] = 'translateX(-100%)' } if (index > vm.activeIndex) { style['transform'] = 'translateX(100%)' } style['transition'] = vm.isAnimation ? 'transform 0.5s ease-out' : 'transform 0s ease-out' return style }
然后就是處理touchstart touchend touchmove事件了,這里就不貼代碼了,說下邏輯:
坑點
因為這個組件是通過css3的transition來實現動畫的,最開始我是把所用三個滑動元素在css里面寫了transition:transform 0.5s ease-out; 誰知道自己把自己坑了,因為最后我們改變activeIndex后要刪除一個日期,還要往數組里面新增一個元素,這樣就會引起dates的改變,進而引起Vue去重新更新界面,導致動畫又出來了!最后想到的解決辦法就是引入一個變量isAnimation來控制transition的值,只有當滑動的時才開啟過度動畫效果,再偵聽transitionend時間重置isAnimation = false后再更新dates
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。
新聞熱點
疑難解答