vue实现滑动切换效果(仅在手机模式下可用)
前端  /  管理员 发布于 4年前   816
本文实例为大家分享了vue实现滑动时红黄色块左右滑动相应距离,效果如下图
实现过程主要在于实时跟踪手指滑动位置与原位置之间的偏移量,再相应移动红黄块。
红黄块布局如下
back中包含back-l,back-r左右两块,正常情况下为了隐藏其中一块,子模块需要设置display: inline-block,并且宽度都需要设置width: 100%。父模块中设置white-space: nowrap用于处理两个子模块之间的空白。
父模块监听滑动事件
滑动事件分为三种: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}完整代码
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
您可能感兴趣的文章:
- vue自定义移动端touch事件之点击、滑动、长按事件
- 基于Vue实现页面切换左右滑动效果
- vue实现一个移动端屏蔽滑动的遮罩层实例
- 写一个移动端惯性滑动&回弹Vue导航栏组件 ly-tab
- Vue实现移动端左右滑动效果的方法
- vue中选项卡点击切换且能滑动切换功能的实现代码
- vue中使用better-scroll实现滑动效果及注意事项
上一条:
vuejs移动端实现div拖拽移动
下一条:
Vue实现商品分类菜单数量提示功能Top
- 相关文章
- 使用 Alpine.js 排序插件对元素进行排序(0个评论)
- 在js中使用jszip + file-saver实现批量下载OSS文件功能示例(0个评论)
- 在vue中实现父页面按钮显示子组件中的el-dialog效果(0个评论)
- 使用mock-server实现模拟接口对接流程步骤(0个评论)
- vue项目打包程序实现把项目打包成一个exe可执行程序(0个评论)
- 近期文章
- 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
- Laravel从Accel获得5700万美元A轮融资(0个评论)
- 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
- 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
- PHP 8.4 Alpha 1现已发布!(0个评论)
- Laravel 11.15版本发布 - Eloquent Builder中添加的泛型(0个评论)
- Laravel 11.14版本发布 - 新的字符串助手和ServeCommand改进(0个评论)
- Laravel 11.12版本发布 - Artisan的`make`命令自动剪切`.php `扩展(0个评论)
- golang支持托盘的程序模板:fyneMiniProgram-程序带图标,程序最小化到系统栏(0个评论)
- Laravel的轻量型购物车扩展包:binafy/laravel-cart(0个评论)
- 近期评论
123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..路人 在
php中使用hyperf框架调用讯飞星火大模型实现国内版chatgpt功能示例中评论 教程很详细,如果加个前端chatgpt对话页面就完美了..
Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号