Vue.js移動(dòng)端左滑刪除組件的實(shí)現(xiàn)代碼
左滑刪除在移動(dòng)端很常見(jiàn)。下面我們一起來(lái)封裝一下這個(gè)簡(jiǎn)單的小組件。我們想要是:
- 當(dāng)滑塊沒(méi)有超過(guò)刪除按鈕的一半時(shí)自動(dòng)回到起點(diǎn)位置。
- 滑動(dòng)距離超過(guò)一半滑動(dòng)到最大值(刪除按鈕寬度)
- 盡量精簡(jiǎn)代碼
效果如下:

在開(kāi)始之前,我們先得將 [touchEventApi][1]弄清楚了。這個(gè)小組件中,用到了:
1. TouchEvent.touches (表示一 個(gè) TouchList 對(duì)象,包含了所有當(dāng)前接觸觸摸平面的觸點(diǎn)的Touch對(duì)象)
2. TouchEvent.changedTouches (一個(gè) TouchList 對(duì)象,包含了代表所有從上一次觸摸事件到此次事件過(guò)程中,
狀態(tài)發(fā)生了改變的觸點(diǎn)的 Touch 對(duì)象。)
話不多說(shuō),直接上代碼:
<template>
<div class="delete">
<div class="slider">
<div class="content"
@touchstart='touchStart'
@touchmove='touchMove'
@touchend='touchEnd'
:style="deleteSlider"
>
<!-- 插槽中放具體項(xiàng)目中需要內(nèi)容 -->
<slot></slot>
</div>
<div class="remove" ref='remove'>
刪除
</div>
</div>
</div>
</template>
然后是css,這里我使用的是less
<style scoped lang="less" scoped>
.slider{
width: 100%;
height:200px;
position: relative;
user-select: none;
.content{
position: absolute;
left: 0;
right: 0;
top: 0;
bottom: 0;
background:green;
z-index: 100;
// 設(shè)置過(guò)渡動(dòng)畫(huà)
transition: 0.3s;
}
.remove{
position: absolute;
width:200px;
height:200px;
background:red;
right: 0;
top: 0;
color:#fff;
text-align: center;
font-size: 40px;
line-height: 200px;
}
}
</style>
<script type="text/ecmascript-6">
export default {
data() {
return {
startX:0, //觸摸位置
endX:0, //結(jié)束位置
moveX: 0, //滑動(dòng)時(shí)的位置
disX: 0, //移動(dòng)距離
deleteSlider: '',//滑動(dòng)時(shí)的效果,使用v-bind:style="deleteSlider"
}
},
methods:{
touchStart(ev){
ev= ev || event
//tounches類(lèi)數(shù)組,等于1時(shí)表示此時(shí)有只有一只手指在觸摸屏幕
if(ev.touches.length == 1){
// 記錄開(kāi)始位置
this.startX = ev.touches[0].clientX;
}
},
touchMove(ev){
ev = ev || event;
//獲取刪除按鈕的寬度,此寬度為滑塊左滑的最大距離
let wd=this.$refs.remove.offsetWidth;
if(ev.touches.length == 1) {
// 滑動(dòng)時(shí)距離瀏覽器左側(cè)實(shí)時(shí)距離
this.moveX = ev.touches[0].clientX
//起始位置減去 實(shí)時(shí)的滑動(dòng)的距離,得到手指實(shí)時(shí)偏移距離
this.disX = this.startX - this.moveX;
console.log(this.disX)
// 如果是向右滑動(dòng)或者不滑動(dòng),不改變滑塊的位置
if(this.disX < 0 || this.disX == 0) {
this.deleteSlider = "transform:translateX(0px)";
// 大于0,表示左滑了,此時(shí)滑塊開(kāi)始滑動(dòng)
}else if (this.disX > 0) {
//具體滑動(dòng)距離我取的是 手指偏移距離*5。
this.deleteSlider = "transform:translateX(-" + this.disX*5 + "px)";
// 最大也只能等于刪除按鈕寬度
if (this.disX*5 >=wd) {
this.deleteSlider = "transform:translateX(-" +wd+ "px)";
}
}
}
},
touchEnd(ev){
ev = ev || event;
let wd=this.$refs.remove.offsetWidth;
if (ev.changedTouches.length == 1) {
let endX = ev.changedTouches[0].clientX;
this.disX = this.startX - endX;
console.log(this.disX)
//如果距離小于刪除按鈕一半,強(qiáng)行回到起點(diǎn)
if ((this.disX*5) < (wd/2)) {
this.deleteSlider = "transform:translateX(0px)";
}else{
//大于一半 滑動(dòng)到最大值
this.deleteSlider = "transform:translateX(-"+wd+ "px)";
}
}
}
}
}
</script>
到這里就全部完成了,希望對(duì)大家有幫助!也希望大家多多支持腳本之家。
相關(guān)文章
Vue?運(yùn)行高德地圖官方樣例,設(shè)置class無(wú)效的解決
這篇文章主要介紹了Vue?運(yùn)行高德地圖官方樣例,設(shè)置class無(wú)效的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10
el-table表頭添加勾選框的實(shí)現(xiàn)示例
本文主要介紹了el-table表頭添加勾選框的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-01-01
Vue利用高德地圖API實(shí)現(xiàn)實(shí)時(shí)天氣
這篇文章主要為大家詳細(xì)介紹了Vue如何利用高德地圖API實(shí)現(xiàn)實(shí)時(shí)天氣,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-12-12
VUE DEMO之模擬登錄個(gè)人中心頁(yè)面之間數(shù)據(jù)傳值實(shí)例
今天小編就為大家分享一篇VUE DEMO之模擬登錄個(gè)人中心頁(yè)面之間數(shù)據(jù)傳值實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-10-10

