web开发touch事件实例详解

本文主要为大家分享一篇移动web开发之touch事件实例详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧,希望能帮助到大家。

前面的话

iOS版Safari为了向开发人员传达一些特殊信息,新增了一些专有事件。因为iOS设备既没有鼠标也没有键盘,所以在为移动Safari开发交互性网页时,常规的鼠标和键盘事件根本不够用。随着Android 中的WebKit的加入,很多这样的专有事件变成了事实标准,导致W3C开始制定Touch Events规范。本文将详细介绍移动端touch事件

概述

包含iOS 2.0软件的iPhone 3G发布时,也包含了一个新版本的Safari浏览器。这款新的移动Safari提供了一些与触摸(touch)操作相关的新事件。后来,Android上的浏览器也实现了相同的事件。触摸事件会在用户手指放在屏幕上面时、在屏幕上滑动时或从屏幕上移开时触发。具体来说,有以下几个触摸事件

touchstart:当手指触摸屏幕时触发;即使已经有一个手指放在了屏幕上也会触发touchmove:当手指在屏幕上滑动时连续地触发。在这个事件发生期间,调用preventDefault()可以阻止滚动touchend:当手指从屏幕上移开时触发touchcancel:当系统停止跟踪触摸时触发(不常用)。关于此事件的确切触发时间,文档中没有明确说明

【touchenter 和 touchleave】

触摸事件规范中曾经包含touchenter和touchleave事件,这两个事件在用户手指移入或移出某个元素时触发。但是这两个事件从来没有被实现。微软有这两个事件的替代事件,但是只有IE浏览器支持。某些情况下可以知道用户手指滑入滑出某个元素是素是非常有用的,所以希望这两个事件可以重返规范

在触摸事件中,常用的是touchstart、touchumove和touchend这三个事件,与鼠标事件的对应如下

鼠标   触摸   mousedown touchstart mousemove touchmove mouseup  touchend

[注意]touch事件在chrome模拟器下部分版本使用DOM0级事件处理程序的方式来添加事件无效

    Document  #test{height:200px;width:200px;background:lightblue;} 

(function(){ var stateMap = { touchstart_index : 0, touchmove_index : 0, touchend_index : 0 }, elesMap = { touch_obj: document.getElementById('test') }, showIndex, handleTouch; showIndex = function ( type ) { elesMap.touch_obj.innerHTML = type + ':' + (++stateMap[type + '_index']); }; handleTouch = function ( event ) { showIndex( event.type ); }; elesMap.touch_obj.addEventListener('touchstart', function(event){handleTouch(event);}); elesMap.touch_obj.addEventListener('touchmove', function(event){handleTouch(event);}); elesMap.touch_obj.addEventListener('touchend', function(event){handleTouch(event);}); })();

300ms

300ms问题是指在某个元素执行它的功能和执行touch事件之间有一个300毫秒的间隔。鼠标事件、焦点事件、浏览器默认行为等相较于touch事件,都存在着300ms的延迟

【点透】

因为300ms的存在,会造成常见的点透问题。先来看例子

    Document   #test {position: absolute;top: 0;left: 0;opacity: 0.5;height: 200px;width: 200px;background: lightblue;}  百度 

(function () { var elesMap = { touchObj: document.getElementById('test') }, fnHide, onTouch; fnHide = function (type) { elesMap.touchObj.style.display = 'none'; }; onTouch = function (event) { fnHide(); }; elesMap.touchObj.addEventListener('touchstart', function(event){onTouch(event);}); })();

浅蓝色的半透明p被点击(触发touch事件)后,如果点击位置正好位于链接的上方,则会触发链接跳转的默认行为。详细解释是,点击页面后,浏览器会记录所点击的页面坐标,300ms后,在该坐标找到元素。在该元素上触发点击行为。因此,如果300ms内同一页面坐标的上层元素消失后,300ms后在下层元素上触发点击行为。这就造成了点透问题

造成这个问题,是因为触摸屏幕的行为被重载(overload)了。在手指触摸屏幕的瞬间,浏览器无法预知用户是在轻触(Tap)、双触(Double-Tap)、滑动(Swipe)、按住不放(Hold)还是其他什么操作。唯一保险的做法就是等上一会儿看接下来会发生什么

问题是在于双触(Double-Tap)。即便是浏览器检测出手指离开了屏幕,它仍然无法判断接下来做什么。因为浏览器无法知道手指是会再次回到屏幕,还是就此结束触发轻触事件以及事件级联。为了确定这一点,浏览器不得不等待一小段时间。浏览器开发者找到一个最佳时间间隔,就是300毫秒

【解决办法】

1、在touch事件的事件处理程序中增加300ms的延迟

(function () {   var    elesMap = {     touchObj: document.getElementById('test')    },    fnHide, onTouch;   fnHide = function (type) {    elesMap.touchObj.style.display = 'none';   };   onTouch = function (event) {    setTimeout(function(){     fnHide();    },300);   };   elesMap.touchObj.addEventListener('touchstart', function (event) { onTouch(event); });  })();

2、使用缓动动画,增加300ms的过渡效果,注意display属性无法使用transition

3、加入中间层的dom元素,让中间层接受这个穿透事件,稍后隐藏

4、上下两级都使用tap事件,但默认行为不可避免

5、在document上的touchstart事件,阻止默认行为。

document.addEventListener('touchstart',function(e){  e.preventDefault();})

接着,添加a标签的跳转行为

a.addEventListener('touchstart',function(){ window.location.href = 'https://cnblogs.com'; })

但是,这种方法有副作用,会造成页面无法滚动、文本无法选中等。如果在某个元素上,需要恢复文本选中的行为,则可以使用阻止冒泡来恢复

el.addEventListener('touchstart',function(e){  e.stopPropagation();})

事件对象

【基础信息】

每个触摸事件的event对象都提供了在鼠标事件中常见的属性,包括事件类型、事件目标对象、事件冒泡、事件流、默认行为等

以touchstart为例,示例代码如下

  (function () {   var    elesMap = {     touchObj: document.getElementById('test')    },    onTouch;   onTouch = function (e) {     console.log(e)  };   elesMap.touchObj.addEventListener('touchstart', function (event) { onTouch(event); });  })();  

1、currentTarget属性返回事件正在执行的监听函数所绑定的节点

2、target属性返回事件的实际目标节点

3、srcElement属性与target属性功能一致

//当前目标currentTarget:[object HTMLpElement]//实际目标target:[object HTMLpElement]//实际目标srcElement:[object HTMLpElement]

4、eventPhase属性返回一个整数值,表示事件目前所处的事件流阶段。0表示事件没有发生,1表示捕获阶段,2表示目标阶段,3表示冒泡阶段

5、bubbles属性返回一个布尔值,表示当前事件是否会冒泡。该属性为只读属性

6、cancelable属性返回一个布尔值,表示事件是否可以取消。该属性为只读属性

//事件流eventPhase: 2//可冒泡bubbles: true//默认事件可取消cancelable: true

【touchList】

除了常见的DOM属性外,触摸事件对象有一个touchList数组属性,其中包含了每个触摸点的信息。如果用户使用四个手指触摸屏幕,这个数组就会有四个元素。一共有三个这样的数组

1、touches:当前触摸屏幕的触摸点数组(至少有一个触摸在事件目标元素上)

2、changedTouches :导致触摸事件被触发的触摸点数组

3、targetTouches:事件目标元素上的触摸点数组

如果用户最后一个手指离开屏幕触发touchend事件,这最后一个触摸点信息不会出现在targetTouches和touches数组中,但是会出现在changedTouched数组中。因为是它的离开触发了touchend事件,所以changedTouches数组中仍然包含它。上面三个数组中,最常用的是changedTouches数组

(function () {   var    elesMap = {     touchObj: document.getElementById('test')    },    onTouch;   onTouch = function (e) {     elesMap.touchObj.innerHTML = 'touches:' + e.touches.length                  + '
changedTouches:' + e.changedTouches.length + '
targetTouches:' + e.targetTouches.length; }; elesMap.touchObj.addEventListener('touchstart', function (event) { onTouch(event); }); })();

【事件坐标】

上面这些触摸点数组中的元素可以像普通数组那样用数字索引。数组中的元素包含了触摸点的有用信息,尤其是坐标信息。每个Touch对象包含下列属性

clientx:触摸目标在视口中的x坐标clientY:触摸目标在视口中的y坐标identifier:标识触摸的唯一IDpageX:触摸目标在页面中的x坐标(包含滚动)pageY:触摸目标在页面中的y坐标(包含滚动)screenX:触摸目标在屏幕中的x坐标screenY:触摸目标在屏幕中的y坐标target:触摸的DOM节点目标

changedTouches数组中的第一个元素就是导致事件触发的那个触摸点对象(通常这个触摸点数组不包含其他对象)。这个触摸点对象含有clientX/Y和pageX/Y坐标信息。除此之外还有screenX/Y和x/y,这些坐标在浏览器间不太一致,不建议使用

clientX/Y和pageX/Y的区别在于前者相对于视觉视口的左上角,后者相对于布局视口的左上角。布局视口是可以滚动的

(function () {   var    elesMap = {     touchObj: document.getElementById('test')    },    onTouch;   onTouch = function (e) {    var touch = e.changedTouches[0];    elesMap.touchObj.innerHTML = 'clientX:' + touch.clientX + '
clientY:' + touch.clientY + '
pageX:' + touch.pageX + '
pageY:' + touch.pageY + '
screenX:' + touch.screenX + '
screenY:' + touch.screenY }; elesMap.touchObj.addEventListener('touchstart', function (event) { onTouch(event); }); })();

相关推荐:

JS手机端touch事件计算滑动距离的方法

有关touch事件解析和封装的知识

javascript移动设备Web开发中对touch事件的封装实例_javascript技巧

以上就是web开发touch事件实例详解的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1545540.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月21日 17:02:54
下一篇 2025年12月21日 17:03:04

相关推荐

  • Dreamweaver裁剪图片技巧详解

    dreamweaver中插入的图片太大了,想要裁剪图片,dreamweaver怎么裁剪图片?,并设置图片的属性,该怎么设置呢?下面我们就来看看dw编辑图片的技巧,需要的朋友可以参考下,希望能帮助到大家。 1、选中图片,直接在图片的属性中使用宽和高来更来图片的大小,或者是使用裁剪工具来对图片进行裁剪。…

    2025年12月21日 好文分享
    000
  • H5的多线程如何实现Web Worker

    很多人问过我,h5的多线程如何实现web worker的?当我们说到这个问题的时候首先你需要知道,什么是web worker,那么今天就来给大家解答下这个问题。 将JavaScript代码交给Web Worker在后台执行时,页面就可以在JavaScript运行期间依然可以响应用户操作,以防止出现页…

    好文分享 2025年12月21日
    000
  • H5中的弹窗无法用webview弹出怎么解决

    我们偶尔会用到这样一种bug,虽然使用了webview,但是还无法吊起h5中的弹窗。那么怎么解决这个问题呢?我们来看一下。 问题: webview无法吊起H5中的弹窗。 解决方法: 如果是fragment,必须使用getactivity()上下文,不能用全家上下文,否则无法弹窗。 mWebView.…

    好文分享 2025年12月21日
    000
  • html与xhtml的区别详解

    今天来给大家详细的介绍一下俩个概念,html和xhtml的相同与不同,帮助大家更好的理解前端技术。 html与xhtml的最主要的不同区别:(以下的讲解例子中将用红色区分) 1、XHTML 元素必须被正确地嵌套。 例子:一般html网页可以“主要内容”这是个不严格,在XHTML是错误的;正确的在xh…

    好文分享 2025年12月21日
    000
  • Emmet 的 HTML 语法详解

    本文主要介绍 emmet 的 html 语法,看完之后,你就会看懂并且会写出那句代码了。现在,打开你的 st2 然后新建一个 html 文档,跟着文章,即时输入对应的指令然后亲自尝试一下!生成 html 文档初始结构html 文档的初始结构,就是包括 doctype、html、head、body 以…

    2025年12月21日
    000
  • JavaScript中的同步与异步的详解

    在javascript中,一个线程执行的时候不依靠其他线程处理完毕我们称为异步,相反一个线程必须等待直到另一个线程处理完毕我们则称为同步。打个比方:  (1)同步就是你在煮方便面的时候必须等水开了,你才会放调料和方便面;  (2)异步就是你在煮方便面的时候不需要等水开了,你可以刚开始开火的时候,就放…

    好文分享 2025年12月21日
    000
  • 详解HTML5如何操作WebSQL数据库

    下面通过本文给大家分享html5操作websql数据库的实例代码,感兴趣的朋友一起看看吧 HTML代码: 列车时刻表查询 列车时刻表查询 请给我留言 姓名: 留言: 留言 查询 收藏 给我留言 Close 收藏成功,暂且不做处理!. 请点击右上角有个关闭按钮 提示: 你也可以点击弹窗的外部区域来关闭…

    2025年12月21日
    000
  • 关于HTML5中性能优化的详解

    HTML5性能优化 –减少重绘         在HTML页面完成展现之后,动态改变页面元素或调整CSS样式都会引起浏览器重绘,性能的损耗直接取决于动态改变的范围:如果只是改变一个元素的颜色之类的信息则只会重绘该元素;而如果是增删节点或调整节点位置则会引起其兄弟节点也一并重绘。     …

    好文分享 2025年12月21日
    000
  • 如何实现实时应用_javascript中socket.io怎么用?

    实现实时应用的核心是建立客户端与服务器间的双向低延迟通信,Socket.IO通过自动降级、事件驱动、命名空间和房间机制简化开发。服务端用Node.js搭建,客户端通过CDN引入并连接,需注意CORS、事件名一致性及生产环境代理配置。 实现实时应用,核心是建立客户端和服务器之间的双向、低延迟通信。So…

    2025年12月21日
    000
  • 服务端框架_javascript应用开发

    Node.js是服务端JavaScript的基础,基于V8引擎,采用事件驱动、非阻塞I/O模型,适合高并发场景。其核心优势包括统一语言栈、丰富的npm生态和高效轻量特性。主流框架有Express.js(轻量API)、Koa.js(现代异步处理)、NestJS(企业级模块化)和Fastify(高性能)…

    2025年12月21日
    000
  • JS如何调用SpringWebSocket服务_JS调用SpringWebSocket服务的完整教程

    前端通过STOMP over WebSocket与Spring后端通信,需引入sockjs-client和stompjs库;首先配置Spring WebSocket支持STOMP,定义端点如/ws、消息代理前缀/topic及应用前缀/app;前端使用SockJS连接/ws,通过Stomp.over建…

    2025年12月21日
    000
  • MQTT.js在浏览器中连接WebSocket:解决TypeError错误

    在浏览器环境中使用mqtt.js时,若遇到typeerror: n.createconnection is not a function错误,通常是由于浏览器安全限制不允许直接建立tcp连接。核心解决方案是确保mqtt broker支持websocket协议,并将客户端连接url从mqtt://改为…

    2025年12月21日
    000
  • JavaScript WebSocket实时应用

    WebSocket协议实现全双工通信,适用于实时聊天等场景;通过JavaScript的WebSocket API建立连接并监听事件,结合Node.js的ws库实现消息广播与客户端交互,需处理断开重连以保证稳定性。 WebSocket 是一种在单个 TCP 连接上进行全双工通信的协议,特别适合需要实时…

    2025年12月20日
    000
  • JavaScript边缘计算应用

    JavaScript 在边缘计算中的应用正变得越来越广泛,主要得益于其轻量、灵活以及在服务端(Node.js)和浏览器端的通用性。边缘计算强调在靠近数据源的位置处理信息,减少延迟、节省带宽并提升响应速度。JavaScript 凭借其生态系统和运行时环境,正在多个边缘场景中发挥关键作用。 1. 边缘函…

    2025年12月20日
    000
  • 使用 Fetch API 在 HTML 中获取并展示动态数据

    本文详细介绍了如何使用 JavaScript 的 Fetch API 从外部接口获取 JSON 数据,并将其动态渲染到 HTML 表格中。文章首先阐明了理解 API 响应结构的重要性,随后对比演示了两种数据渲染方式:一种是逐个创建 DOM 元素的传统方法,另一种是利用 `innerHTML` 和模板…

    2025年12月20日
    000
  • JavaScript动态表格行中获取选中下拉框ID及对应行ID的教程

    本教程详细阐述了如何在JavaScript中高效获取动态添加的表格行中,下拉选择框(select)的选中值及其所属行(tr)的唯一ID。通过使用onchange事件监听、this关键字引用当前元素,并结合closest()方法向上查找父级行ID,本文提供了一套清晰且可复用的解决方案,确保在复杂动态表…

    2025年12月20日
    000
  • JavaScript动态加载图片到DOM:从DOM选择到文件读取的完整教程

    本教程详细探讨了在JavaScript中将用户选择的本地图片动态加载并显示到DOM的常见问题及解决方案。内容涵盖了DOM元素选择器getElementsByClassName与querySelector的区别、appendChild方法的正确使用,以及如何利用FileReader API克服浏览器安…

    2025年12月20日
    000
  • 如何用Node.js实现实时日志分析与监控?

    使用Node.js实现实时日志分析与监控,需通过tail模块监听日志文件新增内容;2. 利用正则解析日志行提取IP、时间、状态码等关键信息;3. 在内存或Redis中统计请求量、错误率并设置告警阈值;4. 通过Socket.IO将数据推送到前端,结合Chart.js等库实现实时可视化展示。 用Nod…

    2025年12月20日 好文分享
    000
  • JS 浏览器视频处理 – 使用 Media Source Extensions 实现流媒体播放

    MSE通过JavaScript控制视频流的加载与缓冲,实现动态码率、直播和Seek操作;需合理设置SourceBuffer、优化编码与网络传输以解决卡顿,相比Flash更安全高效。 使用 Media Source Extensions (MSE) 在浏览器中处理视频流,本质上是赋予了 JavaScr…

    2025年12月20日
    000
  • 聚焦Vue 3.3+ withDefaults 类型错误:原因与解决方案

    本文探讨了Vue 3.3+版本中,使用withDefaults配合defineProps时可能遇到的TypeScript类型不匹配错误,尤其针对非布尔类型属性。文章揭示此问题实为特定IDE(如JetBrains系列)对Vue 3.3+类型推断支持不完善导致的已知bug,并提供了在这些IDE中通过启用…

    2025年12月20日
    000

发表回复

登录后才能评论
关注微信