Vue無限滑動周選擇日期的組件的示例代碼
之前在做一個手機端項目的時候,需要一個左右滑動(按周滑動)選擇日期插件,而且當時這個項目沒有用到Vue。當時又沒有找到合適的第三方插件,就花了點時間用原生JavaScript寫了出來,當時心中就想把它寫成基于Vue的組件,這短時間閑了把它弄出來了!,在這個過程中遇到了一個坑,后面會提出來!
先看效果

思路
根據(jù)用戶傳入日期(不傳默認今天),獲取上一周,當周,下一周對應(yīng)的日期放數(shù)組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'),
}
)
根據(jù)datas 生成每一周對應(yīng)的日期
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事件了,這里就不貼代碼了,說下邏輯:
- ouchstart 記錄滑動起點位置
- touchmove 獲得滑動距離賦值給 vm.distan.x 實時獲得當前周transform
- touchend 改變activeIndex的值,當然改變activeIndex的值是不夠的,要實現(xiàn)無限滑動,就要在操作一下dates,如果是左滑刪除dates的第一個元素并且往dates里面push下下周對應(yīng)日期,如果是右滑刪除最后一個元素并網(wǎng)數(shù)組前面unshift上上周對應(yīng)的日期
坑點
因為這個組件是通過css3的transition來實現(xiàn)動畫的,最開始我是把所用三個滑動元素在css里面寫了transition:transform 0.5s ease-out; 誰知道自己把自己坑了,因為最后我們改變activeIndex后要刪除一個日期,還要往數(shù)組里面新增一個元素,這樣就會引起dates的改變,進而引起Vue去重新更新界面,導致動畫又出來了!最后想到的解決辦法就是引入一個變量isAnimation來控制transition的值,只有當滑動的時才開啟過度動畫效果,再偵聽transitionend時間重置isAnimation = false后再更新dates
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue截圖轉(zhuǎn)base64轉(zhuǎn)文件File異步獲取方式
這篇文章主要介紹了vue截圖轉(zhuǎn)base64轉(zhuǎn)文件File異步獲取方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-03-03
vue.js+Element實現(xiàn)表格里的增刪改查
本篇文章主要介紹了vue.js+Element實現(xiàn)增刪改查,具有一定的參考價值,有興趣的可以了解一下。2017-01-01
vue element-ui v-for循環(huán)el-upload上傳圖片 動態(tài)添加、刪除方式
這篇文章主要介紹了vue element-ui v-for循環(huán)el-upload上傳圖片 動態(tài)添加、刪除方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-10-10
vue3通過ref獲取子組件defineExpose的數(shù)據(jù)和方法
defineExpose是Vue3中新增的選項,用于向父組件暴露子組件內(nèi)部的屬性和方法,通過defineExpose,子組件可以主動控制哪些屬性和方法可以被父組件訪問,本文主要介紹了vue3通過ref獲取子組件defineExpose的數(shù)據(jù)和方法,需要的朋友可以參考下2023-10-10
在?Vue?中使用?dhtmlxGantt?組件時遇到的問題匯總(推薦)
dhtmlxGantt一個功能豐富的甘特圖插件,支持任務(wù)編輯,資源分配和多種視圖模式,這篇文章主要介紹了在?Vue?中使用?dhtmlxGantt?組件時遇到的問題匯總,需要的朋友可以參考下2023-03-03

