HTML5触摸事件详解 touchstart touchmove touchend实战指南
HTML5实战与剖析之触摸事件
谈到HTML5的新事件,很多开发者可能会眼前一亮。不过,得先泼点冷水:虽然标准里添了不少新成员,但现实工作中,我们往往得优先考虑那些“能打仗”的——也就是兼容性广、经过实战检验的特性。今天,我们就聚焦在移动端开发中不可或缺的三个事件:touchstart、touchmove和touchend。
免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈
话说回来,这一套触摸事件的诞生,其实是为了解决一个很具体的问题。早期的iOS设备,像iPhone,既没有鼠标也没有物理键盘。你想,用传统PC端那套鼠标点击、键盘输入的事件模型,去开发移动网页的交互,是不是有点“隔靴搔痒”?正是为了给开发者提供更精准的触控信息,iOS版Safari浏览器率先引入了这一系列事件。很快,Android浏览器也跟进了,如今它们已成为移动Web开发的基石。
简单来说,当用户的手指接触屏幕、在屏幕上滑动、或者最终离开时,都会触发相应的触摸事件。下面我们来拆解一下:
touchstart事件:
当手指第一次接触到屏幕的那一刻,它就被触发了。哪怕屏幕上已经有一根手指了,新落下的手指依然会触发新的touchstart。
touchmove事件:
这个事件在手指于屏幕上滑动时,会连续不断地触发。这里有个很实用的技巧:在这个事件的处理函数中调用preventDefault()方法,可以阻止页面随之滚动,这对于实现自定义的拖拽或滑动组件至关重要。
touchend事件:
顾名思义,当手指从屏幕上抬起来时,它就来报到了。
touchcancel事件:
这个事件比较特殊,它会在系统停止跟踪此次触摸时触发。文档中对其确切触发场景描述得比较模糊,通常可能与系统中断(如来电)或手势识别冲突有关,我们可以将其视为一次触摸的意外终止。
需要注意的是,所有这些事件都支持“冒泡”,也都可以被取消。尽管它们并非源自传统的DOM规范,但其实现完全遵循DOM模式。因此,每个触摸事件的event对象都包含了我们熟悉的那些属性,比如clientX, clientY, screenX, screenY等。
然而,触摸事件的精华在于下面这三个专为跟踪触摸而生的属性:
touches:
这是一个数组,包含了当前屏幕上所有的触摸点(Touch对象)。
targetTouches:
这个数组更聚焦,它只包含当前事件目标元素上的触摸点。
changeTouches:
这个数组记录了自上次事件以来,发生了变化的触摸点。在touchend事件中,你想获取刚离开的那根手指的信息,就得靠它。
那么,每个Touch对象又携带了哪些信息呢? 这就好比一个人的身份证,细节非常丰富:
clientX / clientY:
触摸点相对于浏览器视口的坐标。
pageX / pageY:
触摸点相对于整个文档页面的坐标,会计算滚动偏移。
screenX / screenY:
触摸点相对于设备屏幕的坐标。
identifier:
一个唯一ID,用于标识同一根手指的整个触摸过程(从start到end或cancel)。
target:
最初触发触摸事件的DOM元素。
光看理论确实有点枯燥,对吧?这些属性的妙处,非得在代码里过一遍才能真切体会。下面就是一个简单的实战示例:
Ja vaScript代码
function load (){
document.addEventListener('touchstart', touch, false);
document.addEventListener('touchmove', touch, false);
document.addEventListener('touchend', touch, false);
function touch (event){
var event = event || window.event;
var oInp = document.getElementById("inp");
switch(event.type){
case "touchstart":
oInp.innerHTML = "Touch started (" + event.touches[0].clientX + "," + event.touches[0].clientY + ")";
break;
case "touchend":
// 注意,touchend时用changeTouches
oInp.innerHTML = "
Touch end (" + event.changedTouches[0].clientX + "," + event.changedTouches[0].clientY + ")";
break;
case "touchmove":
event.preventDefault(); // 阻止默认滚动
oInp.innerHTML = "
Touch moved (" + event.touches[0].clientX + "," + event.touches[0].clientY + ")";
break;
}
}
}
window.addEventListener('load', load, false);
HTML代码
在这个例子里,当手指落下(touchstart),触碰点的坐标会显示在div中。手指移动(touchmove)时,我们阻止了页面滚动,并实时更新坐标。当手指抬起(touchend),则通过changeTouches获取最终的触点信息。这里有个关键点:touchend触发时,touches数组里通常已经没有东西了,因为对应手指的触摸活动已经结束。
更有趣的是触摸事件与鼠标事件的协同(或者说“竞争”)关系。当你轻触一个可点击的元素时,浏览器为了保证旧有鼠标逻辑的兼容,会按顺序触发一系列事件:
- touchstart
- mouseover
- mousemove (一次)
- mousedown
- mouseup
- click
- touchend
理解这个顺序对于处理混合交互和避免事件冲突非常重要。
最后,聊聊大家最关心的兼容性。支持touchstart, touchmove, touchend的浏览器阵营已经相当强大:包括iOS Safari、Android WebKit、Opera Mobile 10.1+、以及PC端的Firefox和Chrome也早已支持。不过需要注意的是,原生的多点触摸支持(即同时跟踪多个identifier)在早年主要还是iOS Safari的强项,如今现代浏览器的支持都已非常完善。
触摸事件是移动端交互的底层核心,掌握它们,就等于拿到了构建流畅移动体验的钥匙。希望今天的梳理能帮助你更好地在项目中运用它们。
游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。
同类文章
jstat监控新生代对象增长速率与S区年龄分布动态平衡
实时监控新生代变量增长速率与Survivor区对象年龄分布的动态平衡,对预测MinorGC频率和内存风险至关重要。使用jstat工具持续采样关键时序指标,如Eden区使用量斜率可反映对象增长速率。结合对象年龄分布分析,能识别不同模式下的GC压力,例如高增长速率伴随低龄对象主导可能引发频繁GC,需及时调整优化。
异常性能开销分析揭示为何避免用try-catch替代逻辑判断
在软件开发的日常实践中,开发者常常面临一个关于代码性能与结构清晰度的经典权衡:是否可以使用异常处理机制(try-catch)来替代常规的条件判断逻辑(if-else)?明确的答案是:不应该这样做。这并非仅仅是编码风格的偏好问题,其背后涉及深刻的性能损耗与软件设计哲学。 其根本原因在于,异常的实例化与
使用phpEnv安装AppFlowy搭建Notion替代工具教程
先说一个核心结论:如果你正尝试用phpEnv来安装或运行AppFlowy,那这条路从一开始就走不通。AppFlowy是一个用Rust编写、通过Flutter构建的原生桌面应用,它和PHP、MySQL、Apache这套经典的Web服务栈没有任何关系。简单来说,它既不是PHP项目,也不依赖Web服务器,
Systemarraycopy方法实现数组元素覆盖模拟缓存行擦除操作
在Java编程中,System arraycopy()是实现高效数组复制的核心方法,但它本身并不直接提供数据“擦除”功能。所谓的“模拟缓存行擦除”,其核心原理是利用特定的默认值(如0、null或业务定义的无效标记)批量覆盖目标数组的指定区域,从而在逻辑上使旧数据失效。这种技术在实现轻量级环形缓冲区、
Scanner.useLocale方法详解确保多语言环境小数点数值解析正确
Scanner useLocale()方法要求输入字符串格式与所设Locale完全匹配,无法自动转换小数点格式。常见错误包括环境与输入不匹配、混合格式数据源处理不当。可靠方案是预处理输入或使用NumberFormat类。Locale设置即时生效且不影响其他实例,需注意数字解析与空白分割是独立机制。
- 日榜
- 周榜
- 月榜
1
2
3
4
5
6
7
8
9
10
1
2
3
4
5
6
7
8
9
10
相关攻略
2015-03-10 11:25
2015-03-10 11:05
2021-08-04 13:30
2015-03-10 11:22
2015-03-10 12:39
2022-05-16 18:57
2025-05-23 13:43
2025-05-23 14:01
热门教程
- 游戏攻略
- 安卓教程
- 苹果教程
- 电脑教程
热门话题

