亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

vue實現滑動切換效果(僅在手機模式下可用)

2019-11-19 11:07:54
字體:
來源:轉載
供稿:網友

本文實例為大家分享了vue實現滑動時紅黃色塊左右滑動相應距離,效果如下圖

實現過程主要在于實時跟蹤手指滑動位置與原位置之間的偏移量,再相應移動紅黃塊。

紅黃塊布局如下

back中包含back-l,back-r左右兩塊,正常情況下為了隱藏其中一塊,子模塊需要設置display: inline-block,并且寬度都需要設置width: 100%。父模塊中設置white-space: nowrap用于處理兩個子模塊之間的空白。

<template lang="html"> <div class="back" @touchstart.prevent="touchStart" @touchmove.prevent="touchMove" @touchend="touchEnd" ref="back">  <div class="back-l" ref="left"></div>  <div class="back-r" ref="right"></div> </div></template> <style scoped lang="stylus" rel="stylesheet/stylus">.back position: fixed width: 100% height: 100px white-space: nowrap .back-l  position: relative  vertical-align: top  display: inline-block  width: 100%  height: 100%  background-color: red .back-r  display: inline-block  vertical-align: top  position: relative  width: 100%  height: 100%  background-color: yellow</style>

父模塊監聽滑動事件

滑動事件分為三種:touchstart,touchmove,touchEnd,加上prevent避免頁面相應滑動。

在touchstart中記錄滑動開始點:

touchStart(e) {   const touch = e.touches[0]   this.touch.startX = touch.pageX   this.touch.startY = touch.pageY  }

touchmove中為滑動過程,手指未離開頁面,離開頁面時觸發touchend?;瑒舆^程中,當橫向偏離位置大于縱向偏離位置時認為滑動有效,記錄手指偏離位置,相應移動紅黃塊。

touchMove(e) {   console.log("move");   const touch = e.touches[0]   //橫向和縱向偏離位置   const deltaX = touch.pageX - this.touch.startX   const deltaY = touch.pageY - this.touch.startY   if (Math.abs(deltaY) > Math.abs(deltaX)) {    return   }   const left = this.currentPlay == 'red' ? 0 : -window.innerWidth   var offsetWidth = Math.min(0, Math.max(-window.innerWidth,left+deltaX))   //記錄滑動的距離占屏幕寬度的百分比,如果滑動太少則不切換   this.percent = Math.abs(offsetWidth/window.innerWidth)   //移動紅黃塊      this.$refs.back.style["transform"] = `translate3d(${offsetWidth}px,0,0)`   //設置動畫時間      this.$refs.back.style["transitionDuration"] = 10  }

計算偏移量時首先需要知道當前偏移位置,如果當前在紅塊,初始偏移量為0,否則初始偏移量為負的屏幕寬度。初始偏移量加上橫向偏移量首先和-window.innerWidth取最大值,-window.innerWidth為最左偏移量。再和0相比較取最小值,偏移量為0或者大于零則不再(向右移動)移動,小于零則可以向左移動。

touchend中處理最終效果,如果滑動距離不大于某一值則恢復原位,否則切換。

touchEnd() { console.log("end"); console.log(this.percent); let offsetWidth let percent //當前為紅色,滑動占比大于0.1則切換,否則回到原位置 if(this.currentPlay === 'red'){  if(this.percent > 0.1) {   this.currentPlay = 'yellow'   offsetWidth = -window.innerWidth  } else {   offsetWidth = 0  } } else { //當前為黃色,滑動占比大于0.9則切換,否則回到原位置  if(this.percent < 0.9) {   this.currentPlay = 'red'   offsetWidth = 0  } else {   offsetWidth = -window.innerWidth  } } //這里的transform是針對最開始的位置而言,而不是移動過程中的位置 this.$refs.back.style["transform"] = `translate3d(${offsetWidth}px,0,0)` this.$refs.back.style["transitionDuration"] = 10}

完整代碼

<template lang="html"> <div class="back" @touchstart.prevent="touchStart" @touchmove.prevent="touchMove" @touchend="touchEnd" ref="back">  <div class="back-l" ref="left"></div>  <div class="back-r" ref="right"></div>  </div></template> <script>export default { data() {  return {   currentPlay: 'red',   percent: 0  } }, created() {  this.touch = {} }, methods: {  touchStart(e) {   const touch = e.touches[0]   this.touch.startX = touch.pageX   this.touch.startY = touch.pageY  },  touchMove(e) {   console.log("move");   const touch = e.touches[0]   const deltaX = touch.pageX - this.touch.startX   const deltaY = touch.pageY - this.touch.startY   if (Math.abs(deltaY) > Math.abs(deltaX)) {    return   }   const left = this.currentPlay == 'red' ? 0 : -window.innerWidth   var offsetWidth = Math.min(0, Math.max(-window.innerWidth,left+deltaX))   this.percent = Math.abs(offsetWidth/window.innerWidth)   this.$refs.back.style["transform"] = `translate3d(${offsetWidth}px,0,0)`   this.$refs.back.style["transitionDuration"] = 10     },  touchEnd() {   console.log("end");   console.log(this.percent);   let offsetWidth   let percent   if(this.currentPlay === 'red'){    if(this.percent > 0.1) {     this.currentPlay = 'yellow'     offsetWidth = -window.innerWidth    } else {     offsetWidth = 0    }   } else {    if(this.percent < 0.9) {     this.currentPlay = 'red'     offsetWidth = 0    } else {     offsetWidth = -window.innerWidth    }   }   this.$refs.back.style["transform"] = `translate3d(${offsetWidth}px,0,0)`   this.$refs.back.style["transitionDuration"] = 10  } }}</script> <style scoped lang="stylus" rel="stylesheet/stylus">.back position: fixed width: 100% height: 100px white-space: nowrap .back-l  position: relative  vertical-align: top  display: inline-block  width: 100%  height: 100%  background-color: red .back-r  display: inline-block  vertical-align: top  position: relative  width: 100%  height: 100%  background-color: yellow  </style>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91精品久久久久久久久青青| 国产免费观看久久黄| 一区二区三区国产在线观看| 精品人伦一区二区三区蜜桃网站| 欧美裸体视频网站| 欧美视频裸体精品| 久久男人av资源网站| 精品福利视频导航| 国产精品私拍pans大尺度在线| 亚洲影院色在线观看免费| 午夜精品久久久久久久男人的天堂| 97精品在线视频| 在线视频一区二区| 国产精品免费久久久久影院| 精品国产乱码久久久久久虫虫漫画| 欧美成人一二三| 欧美中文字幕在线| 精品二区三区线观看| 亚洲国产美女久久久久| 亚洲欧美一区二区激情| 成人免费网站在线| 久久久成人精品| 欧美老妇交乱视频| 欧美最猛性xxxxx亚洲精品| 国产专区精品视频| 韩国视频理论视频久久| 国产一区二区丝袜| 国产亚洲精品一区二555| 国产精品亚洲一区二区三区| 欧美日韩国产精品一区二区不卡中文| 欧美电影电视剧在线观看| 日韩成人在线网站| 成人在线一区二区| 一区二区三区 在线观看视| 国产成人在线亚洲欧美| 全球成人中文在线| 亚洲精品动漫久久久久| 在线播放国产精品| 国产69精品99久久久久久宅男| 久久夜色精品国产| 热久久这里只有精品| 久久久久这里只有精品| 欧美日韩福利在线观看| 欧美成人性色生活仑片| 国产日韩欧美日韩大片| 欧美成人激情视频| 亚洲欧美日韩一区二区三区在线| 久久精品国产久精国产思思| xxxxxxxxx欧美| 国内精品国产三级国产在线专| 国产亚洲精品久久久久久777| 国内免费精品永久在线视频| 国产精品视频免费在线| 国产精品久久久久久av福利| 亚洲欧美成人在线| 亚洲欧美日韩中文在线制服| 中文字幕久热精品在线视频| 日产日韩在线亚洲欧美| 国产精品久久国产精品99gif| 国产免费一区视频观看免费| 91精品在线播放| 日韩精品免费电影| 亚洲精品美女久久| 国产在线视频2019最新视频| 日韩欧美在线免费观看| 国产精品直播网红| 亚洲国产高清福利视频| 欧美成人黑人xx视频免费观看| 久久亚洲国产精品| 日韩电影视频免费| 色妞欧美日韩在线| 精品久久在线播放| 欧美日韩在线观看视频小说| 亚洲高清久久网| 欧美野外猛男的大粗鳮| 91精品久久久久久久久久另类| 高清一区二区三区日本久| 久久久国产成人精品| 日韩美女免费观看| 国产日韩换脸av一区在线观看| 日韩av在线播放资源| 欧美成人精品在线观看| 久久婷婷国产麻豆91天堂| 成人中文字幕+乱码+中文字幕| 中文字幕亚洲自拍| 国产精品久久久久久久av大片| 国产69精品久久久久9| 国产精品激情av电影在线观看| 亚洲欧美国内爽妇网| 岛国av一区二区在线在线观看| 色综合久久88| 亚洲第一av网站| 亚洲va欧美va国产综合久久| 国产精品美女久久久免费| 欧美在线视频免费播放| 欧美激情一区二区三区成人| 久久人人爽人人爽人人片av高请| 国产欧美一区二区三区久久人妖| 国产91精品网站| 精品视频在线导航| 国产精品久久97| 精品久久久一区二区| 亚洲xxxxx电影| 亚洲嫩模很污视频| 国产精品成人在线| 亚洲变态欧美另类捆绑| 97精品在线视频| 国产亚洲激情视频在线| 色综久久综合桃花网| 欧美日韩国产999| 精品高清美女精品国产区| 欧美日韩中文字幕在线视频| 2019中文字幕免费视频| 亚洲欧洲日韩国产| 国模精品一区二区三区色天香| 欧美激情视频在线免费观看 欧美视频免费一| 亚洲第一色中文字幕| 久久久久久久久久久国产| 中文字幕亚洲天堂| 久久亚洲精品中文字幕冲田杏梨| 久久视频在线直播| 亚洲视频999| 欧美又大粗又爽又黄大片视频| 欧美成人亚洲成人日韩成人| 国产成人高清激情视频在线观看| 欧美另类极品videosbest最新版本| 亚洲第一男人天堂| 亚州国产精品久久久| 粗暴蹂躏中文一区二区三区| 亚洲欧美日韩中文在线| 国外成人在线直播| 在线观看久久av| 92裸体在线视频网站| 欧美成人黄色小视频| 久久国产精品影片| 久久久久五月天| 美日韩精品免费视频| 欧美第一黄网免费网站| 国产成人av网| 日本在线精品视频| 中文字幕精品影院| 久久久亚洲天堂| 国产精品高潮粉嫩av| 久久色在线播放| 日韩欧美一区二区在线| 清纯唯美日韩制服另类| 国产精品一区二区久久国产| 国产精品久久国产精品99gif| 日韩精品有码在线观看| 久久久久久免费精品| 亚洲成年网站在线观看| 97免费中文视频在线观看| 黑丝美女久久久| 欧美成人精品在线播放| 日韩女优人人人人射在线视频| 亚洲精品免费av| 国产精品久久久久久久久粉嫩av| 亚洲网站视频福利| 亚洲色图综合网| 亚洲精品视频在线播放| 欧美日韩免费一区| 中文字幕欧美精品日韩中文字幕| 国产精品h片在线播放| 成人国产精品av|