JS-移动端判断上拉和下滑
2017-08-07 09:32
134 查看
一、手指触屏,利用touchstart和touchend计算前后滑动距离,判断是上拉还是下滑。
二、js中距离:pageY、clientY、offsetY的区别:
offsetY:相对于父节点的偏移距离。
clientY:相对于浏览器,滚轮距离不算在内。
pageY:相对于浏览器,滚轮滚动的距离算在内;本例中,用pageY,触屏时记录位置-startY,结束时记录-endY,两个相减以正负判断是上移还是下滑。
三、touchstart有touches属性,touchend有changedTouches属性,两个属性中分别有pageY、pageX信息。
二、js中距离:pageY、clientY、offsetY的区别:
offsetY:相对于父节点的偏移距离。
clientY:相对于浏览器,滚轮距离不算在内。
pageY:相对于浏览器,滚轮滚动的距离算在内;本例中,用pageY,触屏时记录位置-startY,结束时记录-endY,两个相减以正负判断是上移还是下滑。
三、touchstart有touches属性,touchend有changedTouches属性,两个属性中分别有pageY、pageX信息。
//滑动处理 var startX, startY; document.addEventListener('touchstart',function (ev) { startX = ev.touches[0].pageX; startY = ev.touches[0].pageY; }, false); document.addEventListener('touchend',function (ev) { var endX, endY; endX = ev.changedTouches[0].pageX; endY = ev.changedTouches[0].pageY; var direction = GetSlideDirection(startX, startY, endX, endY); switch(direction) { case 0: alert("无操作"); break; case 1: // 向上 alert("up"); break; case 2: // 向下 alert("down"); break; default: } }, false);四、
function GetSlideDirection(startX, startY, endX, endY) { var dy = startY - endY; //var dx = endX - startX; var result = 0; if(dy>0) {//向上滑动 result=1; }else if(dy<0){//向下滑动 result=2; } else { result=0; } return result; }
相关文章推荐
- 移动端,JS判断滑到页面顶部下滑进行操作
- JS实现移动端判断上拉和下滑功能
- js如何判断用户是在PC端和还是移动端访问
- JS判断客户端是否是iOS或者Android手机移动端
- 移动端JS判断手势方向
- JS判断移动端访问设备并解析对应CSS
- JS判断移动端还是PC端(改造自腾讯网) 仅用于宣传动画,下载页等
- JS判断客户端是否是iOS或者Android手机移动端
- JS判断客户端是否是iOS或者Android手机移动端
- JS判断移动端和pc端加载不同页面
- 使用JS判断移动端手机横竖屏状态
- js判断客户端是ios或者是android手机移动端
- js判断设备是否是移动端代码
- JS判断客户端是否是iOS或者Android手机移动端
- JS判断客户端是否是iOS或者Android手机移动端
- 判断是否移动端设备的JS代码
- js 判断移动端系统版本
- 移动端IOS和androi及浏览器js判断[转载]
- js判断pc端还是移动端
- js 判断访问端是否是手机移动端和什么浏览器