Vue左滑組件slider使用詳解
slider組件與swiper組件不同,slider滑動(dòng)時(shí)并不翻頁(yè),實(shí)現(xiàn)的是左滑時(shí),顯示右側(cè)內(nèi)容的功能

1、主要思路
思路和swiper組件類似,主要的也就是對(duì)三個(gè)觸摸事件的處理:touchstart、touchmove、touchend
在touchstart事件處理程序中記錄一些初始值,比如原始坐標(biāo),偏移距離;在touchmove事件處理程序中計(jì)算實(shí)時(shí)滑動(dòng)的距離,讓元素隨之一起偏移,與swiper不同的是,slider在左滑之前,不能右滑,以及滑動(dòng)時(shí),右側(cè)元素的寬度要同步變化;在touchend事件處理程序中計(jì)算最終的滑動(dòng)距離,左滑且大于闕值則滑動(dòng)固定值,右滑或小于闕值則回到起始位置,右側(cè)元素的寬度要同步變化。
slider組件可以接收三個(gè)參數(shù):
rightWidth: 右側(cè)滑出寬度的百分比
isClickBack: 點(diǎn)擊是否收起右側(cè)
isMainSlide: 左側(cè)是否滑動(dòng)(false則覆蓋左側(cè))
2、代碼實(shí)現(xiàn)
頁(yè)面結(jié)構(gòu):有兩個(gè)slot來(lái)展示左右兩邊的內(nèi)容
<template> <div class="ths_slider" ref="slider"> <div class="main" @touchstart="touchstart" @touchmove="touchmove" @touchend="touchend"> <slot name="main"></slot> </div> <div class="right" ref="right"> <slot name="right"></slot> </div> </div> </template>
初始設(shè)置:記錄頁(yè)面寬度,根據(jù)參數(shù)isMainSlide來(lái)判斷滑動(dòng)的元素
mounted () {
this.pageWidth = document.documentElement.clientWidth
this.sliderEle = this.isMainSlide ? this.$refs.slider : this.$refs.right
}
事件處理:
touchstart (e) {
this.originalPos = e.touches[0].pageX
const transform = this.sliderEle.style.transform
this.originalLeft = Number(transform ? transform.split('(')[1].split('px')[0] : 0)
this.oriRigWidth = this.originalLeft < 0 ? Number(this.$refs.right.style.width.split('px')[0]) : 0
},
touchmove (e) {
let moveDistance = e.touches[0].pageX - this.originalPos // >0 右滑,<0 左滑
if (moveDistance > 0 && this.originalLeft >= 0) { // 未向左邊滑動(dòng)時(shí),不能右滑
return false
}
this.doSlide(moveDistance / 2 + this.originalLeft) // 除以2來(lái)控制滑動(dòng)速度
},
touchend (e) {
const moveDistance = e.changedTouches[0].pageX - this.originalPos // >0 右滑,<0 左滑
let distance
if (!this.isClickBack && moveDistance === 0) { // 點(diǎn)擊時(shí)不收起右側(cè)
return false
}
if ((-moveDistance) > 50) { // 向左滑動(dòng)超過(guò)闕值時(shí),右側(cè)滑出固定距離
distance = this.pageWidth * this.rightWidth / 100
} else { // 向左滑動(dòng)未超過(guò)闕值,或向右滑動(dòng)時(shí),回原位
distance = 0
}
this.doSlide(-distance, true)
},
/**
* 滑動(dòng)方法---位置變化 && 右側(cè)寬度變化
* @param {Number} distance 滑動(dòng)距離
* @param {Boolean} animate 滑動(dòng)是否有動(dòng)畫(huà)效果
*/
doSlide (distance, animate = false) {
this.sliderEle.style.transform = `translateX(${distance}px)`
this.$refs.right.style.width = -distance + 'px'
if (this.isMainSlide) {
this.sliderEle.style.transition = animate ? 'transform .5s' : 'initial'
this.$refs.right.style.transition = animate ? 'width .5s' : 'initial'
} else {
this.sliderEle.style.transition = animate ? 'transform .5s, width .5s' : 'initial'
}
}
3、組件使用
父組件可以調(diào)用slider組件的doSlide()方法來(lái)實(shí)現(xiàn)點(diǎn)擊喚出右側(cè)元素
<t-slider class="slider"> <template slot="main">左側(cè)滑動(dòng)</template> <template slot="right"> <div class="edit">編輯</div> <div class="delete">刪除</div> </template> </t-slider> <t-slider class="slider" :rightWidth="rightWidth" :isMainSlide="false"> <template slot="main"> <div>覆蓋左側(cè)</div> <div class="btn" @click="showRight">點(diǎn)擊喚出</div> </template> <template slot="right"> <div class="newContent">newContent</div> </template> </t-slider> <t-slider class="slider" :isClickBack="false"> <template slot="main">點(diǎn)擊不收起</template> <template slot="right"> <div class="edit">編輯</div> <div class="delete">刪除</div> </template> </t-slider>
components: {TSlider},
data () {
return {
pageWidth: null,
rightWidth: 80
}
},
mounted () {
this.pageWidth = document.documentElement.clientWidth
},
methods: {
showRight () {
this.$refs.mainSlider.doSlide(-this.pageWidth * this.rightWidth / 100, true)
}
}
4、效果展示

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue項(xiàng)目中運(yùn)用webpack動(dòng)態(tài)配置打包多種環(huán)境域名的方法
本人分享一個(gè)vue項(xiàng)目里,根據(jù)命令行輸入不同的命令,打包出不同環(huán)境域名的方法。需要的朋友跟隨小編一起看看吧2019-06-06
如何封裝一個(gè)類似微信通訊錄帶有字母檢索功能的vue組件
這篇文章主要介紹了如何封裝一個(gè)類似微信通訊錄帶有字母檢索功能的vue組件問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-08-08
vue2使用?element表格展開(kāi)功能渲染子表格的方式
這篇文章主要介紹了vue2使用?element表格展開(kāi)功能渲染子表格的方式,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2024-01-01
vue.js實(shí)現(xiàn)插入數(shù)值與表達(dá)式的方法分析
這篇文章主要介紹了vue.js實(shí)現(xiàn)插入數(shù)值與表達(dá)式的方法,結(jié)合實(shí)例形式分析了vue.js常見(jiàn)的3種插入數(shù)值實(shí)現(xiàn)方式,并總結(jié)了vue.js插值與表達(dá)式相關(guān)使用技巧,需要的朋友可以參考下2018-07-07
在vue中使用cookie記住用戶上次選擇的實(shí)例(本次例子中為下拉框)
這篇文章主要介紹了在vue中使用cookie記住用戶上次選擇的實(shí)例(本次例子中為下拉框),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-09-09
vue/react單頁(yè)應(yīng)用后退不刷新方案
本文主要介紹了vue/react單頁(yè)應(yīng)用后退不刷新方案,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-10-10
vue 1.0 結(jié)合animate.css定義動(dòng)畫(huà)效果
本文分步驟給大家介紹了Vue 1.0自定義動(dòng)畫(huà)效果,vue1.0代碼結(jié)合animate.css定義動(dòng)畫(huà),頁(yè)面一定要引入animate.cdd,具體實(shí)例代碼大家參考下本文2018-07-07
elementUI中的$confirm調(diào)換兩個(gè)按鈕位置的實(shí)例代碼
這篇文章主要介紹了elementUI中的$confirm調(diào)換兩個(gè)按鈕位置的實(shí)例代碼,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧2024-03-03

