当前位置:主页 > vue.js教程 > vue实现滑动切换效果(仅在手机模式下可用)

vue实现滑动切换效果的实例代码

发布:2020-02-01 20:17:58 98


本站精选了一篇vue相关的编程文章,网友暴冷卉根据主题投稿了本篇教程内容,涉及到vue、滑动切换、vue实现滑动切换效果(仅在手机模式下可用)相关内容,已被669网友关注,下面的电子资料对本篇知识点有更加详尽的解释。

vue实现滑动切换效果(仅在手机模式下可用)

本文实例为大家分享了vue实现滑动时红黄色块左右滑动相应距离,效果如下图

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>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持码农之家。


参考资料

相关文章

  • 实例讲解vue-router传参的两种方式

    发布:2020-02-12

    Vue Router 是 Vue.js 官方的路由管理器。这篇文章主要介绍了详解vue-router传参的两种方式,需要的朋友可以参考下


  • vue iview组件表格 render函数的使用教程

    发布:2020-02-18

    下面小编就为大家分享一篇vue iview组件表格 render函数的使用方法详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧


  • 解决vue-cli不能初始化webpack模板方法

    发布:2020-07-31

    下面小编就为大家分享一篇快速解决vue-cli不能初始化webpack模板的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧


  • 实例讲解vue addRoutes实现动态权限路由菜单

    发布:2020-02-10

    本篇文章主要介绍了vue addRoutes实现动态权限路由菜单的示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧


  • vue中获取token写进header的实例方法

    发布:2019-11-20

    今天小编就为大家分享一篇在vue中获取token,并将token写进header的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧


  • vue2.0组件之间传值、通信的方式总结

    发布:2020-01-06

    这篇文章主要介绍了vue2.0组件之间传值、通信的多种方式以及注意要点,需要的朋友可以参考下


  • 解析vue中鼠标移入移出事件

    发布:2020-03-09

    这篇文章主要介绍了vue实现鼠标移入移出事件,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧


  • vue自定义H5视频播放器的实现代码

    发布:2020-02-01

    这篇文章主要介绍了vue实现自定义H5视频播放器的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧


网友讨论