html5手机触屏touch事件的详细介绍


本文摘自PHP中文网,作者黄舟,侵删。

HTML5中新添加了很多事件,但是由于他们的兼容问题不是很理想,应用实战性不是太强,所以在这里基本省略,咱们只分享应用广泛兼容不错的事件,日后随着兼容情况提升以后再陆续添加分享。

今天为大家介绍的事件主要是触摸事件:

touchstart:触摸开始的时候触发
touchmove:手指在屏幕上滑动的时候触发
touchend:触摸结束的时候触发

而每个触摸事件都包括了三个触摸列表,每个列表里包含了对应的一系列触摸点(用来实现多点触控):

touches:当前位于屏幕上的所有手指的列表。
targetTouches:位于当前DOM元素上手指的列表。
changedTouches:涉及当前事件手指的列表。

每个触摸点由包含了如下触摸信息(常用):

identifier:一个数值,唯一标识触摸会话(touch session)中的当前手指。一般为从0开始的流水号(android4.1,uc)
target:DOM元素,是动作所针对的目标。
pageX/pageX/clientX/clientY/screenX/screenY:一个数值,动作在屏幕上发生的位置(page包含滚动距离,client不包含滚动距离,screen则以屏幕为基准)。 
radiusX/radiusY/rotationAngle:画出大约相当于手指形状的椭圆形,分别为椭圆形的两个半径和旋转角度。初步测试浏览器不支持,好在功能不常用,欢迎大家反馈。

代码如下:

1

2

3

4

5

6

7

8

9

10

11

var obj = document.getElementByIdx_x('id');

obj.addEventListener('touchmove', function(event) {

     // 如果这个元素的位置内只有一个手指的话

    if (event.targetTouches.length == 1) {

     event.preventDefault();// 阻止浏览器默认事件,重要

        var touch = event.targetTouches[0];

        // 把元素放在手指所在的位置

        obj.style.left = touch.pageX-50 + 'px';

        obj.style.top = touch.pageY-50 + 'px';

        }

}, false);

以上就是html5手机触屏touch事件的详细介绍的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

HTML5+canvas调用手机拍照功能实现图片上传功能(图文详解下篇)

HTML5缓存机制是什么?怎么更新缓存

h5的移动端适配怎样实现

HTML5 table标签的样式介绍(另附HTML5 table css居中的实例)

浏览器中5种常用的事件解析

如何自动获取HTML5的data-*属性示例代码详解

h5实现拖拉上传文件

如何在HTML5中使用svg

HTML5视频播放的详细介绍

如何使用HTML5时钟实现(附代码)

更多相关阅读请进入《HTML5》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...