微信小程序 页面滑动事件的实例详解


Posted in Javascript onOctober 12, 2017

微信小程序——页面滑动事件

wxml:

<view id="id" class = "ball" bindtap = "handletap" bindtouchstart = "handletouchtart" bindtouchmove="handletouchmove" bindtouchend="handletouchend" style = "width : 100%px; height : 40px;">
 {{text}}
 </view>

wxss:

.ball {
  box-shadow:2px 2px 10px #AAA;
  border-radius: 20px;
  position: absolute; 
 }

js:

//js
Page({
 data: {
  lastX: 0,     //滑动开始x轴位置
  lastY: 0,     //滑动开始y轴位置
  text: "没有滑动",
  currentGesture: 0, //标识手势
 },
 //滑动移动事件
 handletouchmove: function (event) {
  var currentX = event.touches[0].pageX
  var currentY = event.touches[0].pageY
  var tx = currentX - this.data.lastX
  var ty = currentY - this.data.lastY
  var text = ""
  //左右方向滑动
  if (Math.abs(tx) > Math.abs(ty)) {
   if (tx < 0)
    text = "向左滑动"
   else if (tx > 0)
    text = "向右滑动"
  }
  //上下方向滑动
  else {
   if (ty < 0)
    text = "向上滑动"
   else if (ty > 0)
    text = "向下滑动"
  }

  //将当前坐标进行保存以进行下一次计算
  this.data.lastX = currentX
  this.data.lastY = currentY
  this.setData({
   text: text,
  });
 },

 //滑动开始事件
 handletouchtart: function (event) {
  this.data.lastX = event.touches[0].pageX
  this.data.lastY = event.touches[0].pageY
 },
 //滑动结束事件
 handletouchend: function (event) {
  this.data.currentGesture = 0;
  this.setData({
   text: "没有滑动",
  });
 },
})

如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

Javascript 相关文章推荐
JavaScript截取字符串的Slice、Substring、Substr函数详解和比较
Mar 20 Javascript
javascript基本类型详解
Nov 28 Javascript
原生JavaScript实现异步多文件上传
Dec 02 Javascript
H5移动端图片压缩上传开发流程
Nov 09 Javascript
详解JS-- 浮点数运算处理
Nov 28 Javascript
jquery.zclip轻量级复制失效问题
Jan 08 Javascript
JS常见算法详解
Feb 28 Javascript
原生实现一个react-redux的代码示例
Jun 08 Javascript
使用JavaScript中的lodash编写双色球效果
Jun 24 Javascript
JS 自执行函数原理及用法
Aug 05 Javascript
微信小程序实现选择地址省市区三级联动
Jun 21 Javascript
Vue实现移动端拖拽交换位置
Jul 29 Javascript
微信小程序 动画的简单实例
Oct 12 #Javascript
node通过npm写一个cli命令行工具
Oct 12 #Javascript
JS实现自定义状态栏动画文字效果示例
Oct 12 #Javascript
AngularJS实现表单验证功能详解
Oct 12 #Javascript
vue mintui-Loadmore结合实现下拉刷新和上拉加载示例
Oct 12 #Javascript
AngularJS 中的数据源的循环输出
Oct 12 #Javascript
详解微信小程序中的页面代码中的模板的封装
Oct 12 #Javascript
You might like
PHPCMS的使用小结
2010/09/20 PHP
探讨如何在PHP开启gzip页面压缩实例
2013/06/09 PHP
PHP面向对象程序设计之命名空间与自动加载类详解
2016/12/02 PHP
php mysql_real_escape_string addslashes及mysql绑定参数防SQL注入攻击
2016/12/23 PHP
浅谈PHP错误类型及屏蔽方法
2017/05/27 PHP
用javascript实现给出的盒子的序列是否可连为一矩型
2007/08/30 Javascript
js中top/parent/frame概述及案例应用
2013/02/06 Javascript
jquery获取特定name所有选中的checkbox,支持IE9标准模式
2013/03/18 Javascript
jQuery 删除/替换DOM元素的几种方式
2014/05/20 Javascript
js面向对象之公有、私有、静态属性和方法详解
2015/04/17 Javascript
浅析Node.js的Stream模块中的Readable对象
2015/07/29 Javascript
详解使用vue-router进行页面切换时滚动条位置与滚动监听事件
2017/03/08 Javascript
vue3.0 搭建项目总结(详细步骤)
2019/05/20 Javascript
Vue实现数据请求拦截
2019/10/23 Javascript
javascript利用canvas实现鼠标拖拽功能
2020/07/23 Javascript
vue实现顶部菜单栏
2020/11/08 Javascript
Python打包文件夹的方法小结(zip,tar,tar.gz等)
2016/09/18 Python
利用Anaconda完美解决Python 2与python 3的共存问题
2017/05/25 Python
Django实现快速分页的方法实例
2017/10/22 Python
Python学习笔记之图片人脸检测识别实例教程
2019/03/06 Python
Python小白必备的8个最常用的内置函数(推荐)
2019/04/03 Python
Mac安装python3的方法步骤
2019/08/09 Python
Python爬取知乎图片代码实现解析
2019/09/17 Python
python爬取音频下载的示例代码
2020/10/19 Python
matplotlib绘制鼠标的十字光标的实现(内置方式)
2021/01/06 Python
美国演唱会订票网站:Ticketmaster美国
2017/10/05 全球购物
英国高街电视:High Street TV
2018/05/22 全球购物
数据库笔试题
2013/05/09 面试题
银行会计业务的个人自我评价
2013/11/02 职场文书
私人房屋买卖协议书
2014/10/04 职场文书
2014年幼师工作总结
2014/11/22 职场文书
追悼词范文大全
2015/06/23 职场文书
高中生社会实践心得体会
2016/01/14 职场文书
2016暑期政治学习心得体会
2016/01/23 职场文书
golang协程池模拟实现群发邮件功能
2021/05/02 Golang
JS前端轻量fabric.js系列之画布初始化
2022/08/05 Javascript