微信小程序实现手势滑动效果


Posted in Javascript onAugust 26, 2019

本文实例为大家分享了微信小程序实现手势滑动的具体代码,供大家参考,具体内容如下

wxml:

<view 
bindtouchstart="touchStart" 
bindtouchmove="touchMove" 
bindtouchend="touchEnd" >
</view>

index.js:

var touchStartX = 0;//触摸时的原点 
var touchStartY = 0;//触摸时的原点 
var time = 0;// 时间记录,用于滑动时且时间小于1s则执行左右滑动 
var interval = "";// 记录/清理时间记录 
var touchMoveX = 0; // x轴方向移动的距离
var touchMoveY = 0; // y轴方向移动的距离

Page({

// 触摸开始事件 
 touchStart: function (e) {
 touchStartX = e.touches[0].pageX; // 获取触摸时的原点 
 touchStartY = e.touches[0].pageY; // 获取触摸时的原点 
 // 使用js计时器记录时间 
 interval = setInterval(function () {
  time++;
 }, 100);
 },
 // 触摸移动事件 
 touchMove: function (e) {
 touchMoveX = e.touches[0].pageX;
 touchMoveY = e.touches[0].pageY;
 },
 // 触摸结束事件 
 touchEnd: function (e) {
 var moveX = touchMoveX - touchStartX
 var moveY = touchMoveY - touchStartY
 if (Math.sign(moveX) == -1) {
  moveX = moveX * -1
 }
 if (Math.sign(moveY) == -1) {
  moveY = moveY * -1
 }
 if (moveX <= moveY) {// 上下
  // 向上滑动
  if (touchMoveY - touchStartY <= -30 && time < 10) {
  console.log("向上滑动")
  }
  // 向下滑动 
  if (touchMoveY - touchStartY >= 30 && time < 10) {
  console.log('向下滑动 ');
  }
 }else {// 左右
  // 向左滑动
  if (touchMoveX - touchStartX <= -30 && time < 10) {
  console.log("左滑页面")
  }
  // 向右滑动 
  if (touchMoveX - touchStartX >= 30 && time < 10) {
  console.log('向右滑动');
  }
 }
 clearInterval(interval); // 清除setInterval 
 time = 0;
 }, 
})

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript while语句和do while语句的区别分析
Dec 08 Javascript
JavaScript中跨域调用Flash的方法
Aug 11 Javascript
JQuery控制div外点击隐藏而div内点击不会隐藏的方法
Jan 13 Javascript
jQuery使用serialize()表单序列化时出现中文乱码问题的解决办法
Jul 27 Javascript
javascript cookie用法基础教程(概念,设置,读取及删除)
Sep 20 Javascript
js实现将json数组显示前台table中
Jan 10 Javascript
vue-cli之router基本使用方法详解
Oct 17 Javascript
Vue.directive()的用法和实例详解
Mar 04 Javascript
解决低版本的浏览器不支持es6的import问题
Mar 09 Javascript
Vue下路由History模式打包后页面空白的解决方法
Jun 29 Javascript
iview tabs 顶部导航栏和模块切换栏的示例代码
Mar 04 Javascript
浅谈express.js框架中间件(middleware)
Apr 07 Javascript
详解nuxt 微信公众号支付遇到的问题与解决
Aug 26 #Javascript
Vue路由之JWT身份认证的实现方法
Aug 26 #Javascript
Vue中跨域及打包部署到nginx跨域设置方法
Aug 26 #Javascript
js实现跟随鼠标移动的小球
Aug 26 #Javascript
vue 源码解析之虚拟Dom-render
Aug 26 #Javascript
Node.js爬虫如何获取天气和每日问候详解
Aug 26 #Javascript
vue移动端实现手机左右滑动入场动画
Jun 17 #Javascript
You might like
php7基于递归实现删除空文件夹的方法示例
2017/06/15 PHP
将HTMLCollection/NodeList/伪数组转换成数组的实现方法
2011/06/20 Javascript
解决遍历时Array.indexOf产生的性能问题
2012/07/03 Javascript
用JS在浏览器中创建下载文件
2014/03/05 Javascript
省市区三级联动下拉框菜单javascript版
2015/08/11 Javascript
jquery mobile界面数据刷新的实现方法
2016/05/28 Javascript
jQuery控制div实现随滚动条滚动效果
2016/06/07 Javascript
ES6记录异步函数的执行时间详解
2016/08/31 Javascript
JavaScript生成图形验证码
2020/08/24 Javascript
微信小程序6位或多位验证码密码输入框功能的实现代码
2018/05/29 Javascript
vue实现键盘输入支付密码功能
2018/08/18 Javascript
vue鼠标移入添加class样式,鼠标移出去除样式(active)实现方法
2018/08/22 Javascript
JavaScript 中 JSON.parse 函数 和 JSON.stringify 函数
2018/12/05 Javascript
Vue中多个元素、组件的过渡及列表过渡的方法示例
2019/02/13 Javascript
layui自己添加图片按钮并点击跳转页面的例子
2019/09/14 Javascript
angular异步验证防抖踩坑实录
2019/12/01 Javascript
Vue项目开发常见问题和解决方案总结
2020/09/11 Javascript
Windows系统下安装Python的SSH模块教程
2015/02/05 Python
python实现自动登录人人网并采集信息的方法
2015/06/28 Python
python实现中文分词FMM算法实例
2015/07/10 Python
一键搞定python连接mysql驱动有关问题(windows版本)
2016/04/23 Python
Python实现matplotlib显示中文的方法详解
2018/02/06 Python
python pandas消除空值和空格以及 Nan数据替换方法
2018/10/30 Python
Selenium启动Chrome时配置选项详解
2020/03/18 Python
TensorFLow 数学运算的示例代码
2020/04/21 Python
美国玛丽莎收藏奢华时尚商店:Marissa Collections
2016/11/21 全球购物
英语感恩演讲稿
2014/01/14 职场文书
经理任命书模板
2014/06/06 职场文书
品质口号大全
2014/06/17 职场文书
爱护公共设施标语
2014/06/24 职场文书
授权委托书格式范文
2014/08/02 职场文书
2015年护士节活动总结
2015/02/10 职场文书
统计工作个人总结
2015/03/03 职场文书
Nginx反向代理及负载均衡如何实现(基于linux)
2021/03/31 Servers
Python基于百度AI实现抓取表情包
2021/06/27 Python
Win10/Win11 任务栏替换成经典样式
2022/04/19 数码科技