「移动端」touch事件,touchEvent对象
随着智能手机普及,有越来越多的手机网页和网页版游戏,手机触摸、移动、旋转等等,多种操作。一般电脑的人机交互靠的是鼠标,而手机用的就是触摸。区别有:
- PC 端一个电脑只能有一个鼠标,而移动端有多点触摸。
- PC 端添加效果使用 mouseup、mousedown、mousemove,而移动端使用的 touchstart、touchmove、touchend 。
一、touch事件类型
- touchstart - 手指触摸屏幕,在元素上按下时触发
- touchmove - 手指移动,在元素上按下之后屏幕上任意移动
- tounchend - 手指在元素上按下之后,屏幕任意位置抬起时触发
- touchcancel - 触摸过程中被系统取消时触发 (很少使用)
touch 事件与mouse事件区别:
- touchstart:手指按下,mousedown:鼠标按下。
- touchmove:手指在屏幕上移动,mousemove:鼠标在网页上移动。
- touchend:手指抬起,mouseup:鼠标弹起。
- touch:事件只能在移动端使用,mouse :事件只能在 PC 端使用。
- touchstart: 只能在绑定元素内按下触发,touchmove、touchend可以在屏幕的任意位置执行。而 mousedown、mousemove、mouseup 都只能在绑定元素内执行。
- touchmove、touchend 只能在 touchstart 触发后,才能执行。但是 mousemove 只要鼠标在绑定元素上,不按下也能执行。
1.1、事件绑定
使用语法:
element.addEventListener( 'eventtype' , function(){} , useCapture )
eg:使用 touchstart 示例:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
.box{
width:200px;
height:200px;
border:solid 1px red;
}
</style>
</head>
<body>
<div class="box"></div>
<script>
window.onload = function(){
let oBox = document.getElementsByClassName('box')[0]
oBox.addEventListener('touchstart',function(ev){
console.log(ev)
},false)
}
</script>
</body>
</html>
每个touch事件的 event 对象,提供了手指触摸过程中的常见属性。打印函数返回的 event 对象,发现有很多参数,如图:
1.2、touchEvent 对象属性
- targetTouches - 当前元素目标上 touch 列表。
- touches - 当前屏幕上的手指触摸 touch 列表。
- changedTouches - 触发当前事件的触摸 touch 列表。
获取方法:
let oBox = document.getElementsByClassName('box')[0]
oBox.addEventListener('touchstart',function(ev){
console.log(ev.touches)
console.log(ev.targetTouches)
console.log(ev.changedTouches)
},false)
上一篇文章我们介绍过,手机如何访问电脑上本地网页,建议使用Browsersync,手机运行网页,手机触摸屏幕,在元素上触摸等观察上述三个属性打印情况。
我们发现它们都是一个数组,每个元素代表一个触摸点。每个触摸点对应的 都有一些重要的属性,分别为:
- clientX - 触摸点在可视区的 x 坐标。
- clientY - 触摸点在可视区的 y 坐标。
- pageX - 触摸点在网页上的 x 坐标。
- pageY - 触摸点在网页上的 y 坐标。
- screenX - 触摸点在屏幕中的 x 坐标。
- screenY - 触摸点在屏幕中的 y 坐标。
- identifier - 触摸点的唯一标识 id。
- target - 触摸的 DOM 节点。
二、触摸分类
很多情况下触摸事件会分为两种,单点触发和多点触发。
单点触发,指的一个指头在屏幕触摸、滑动,主要应用在下拉刷新,手机端banner滑动切换等。
注意:如果是单点触摸,但是有多个手指同时触发,此时需要求三个点的平均值作为触摸点。
多点触发:多个手指同时触摸屏幕,进行旋转、缩放、放大、拖拽等操作。
很多情况下,触摸事件跟鼠标事件会同时触发,目的是为了在pc端运行的时候,没有触摸设备可以使用鼠标代替。如果可以支持触摸事件,则把鼠标事件使用event.preventDefault()阻止事件发生,此时鼠标事件将失效。如果鼠标和触摸事件都支持时,还有添加多个触摸事件时,具体的执行顺序是怎么的?
触摸事件跟鼠标事件的触发先后顺序:
Touchstart > toucheend > mousemove > mousedown > mouseup > click
「移动端」touch事件,touchEvent对象的更多相关文章
- 移动端 js touch事件
随着智能手机和平板电脑的普及, 越来越多的人用移动设备浏览网页,我们平时在pc浏览器上用的鼠标事件,比如:click, mouseover等, 已经无法满足移动设备触摸屏的特点,触摸时代的到来,离不开 ...
- 移动端的touch事件(一)
如果我们允许用户在页面上用类似桌面浏览器鼠标手势的方式来控制WEB APP,这个页面上肯定是有很多可点击区域的,如果用户触摸到了那些可点击区域怎么办呢?? 诸如智能手机和平板电脑一类的移动设备通常会有 ...
- 浅谈移动端之touch事件--手指的滑动事件
今天台风‘海马’袭击深圳,全市停工.现分享一篇关于touch的文章,望指教! 原理: 当开始一个touchstart事件的时候,获取此刻手指的横坐标startX和纵坐标startY: 当触发touch ...
- 移动端html touch事件
诸如智能手机和平板电脑一类的移动设备通常会有一(capacitive touch-sensitivescreen),以捕捉用户的手指所做的交互.随着移动网络的发展,其能够支持越来越复杂的应用,web开 ...
- 对于移动端浏览器touch事件的研究总结(4)判断手指滑动方向
最近有一些微信的项目,虽然页面很简单,但配合手势后的效果却是很不错的.最基本的效果就是手指向上滑,页面配合css3出现一个展开效果,手指向下滑将展开的内容按原路径收起.其实就是一个简单的判断手指滑动方 ...
- 移动端之touch事件--手指的滑动事件
转自[B5教程网]:http://www.bcty365.com/content-142-5243-1.html 总结:touchmove的最后坐标减去touchstart的起始坐标.X的结果如果正数 ...
- 《移动端浏览器Touch事件判断手指滑动方向方法》
$("body").on("touchstart", function(e) { e.preventDefault(); startX = e. ...
- 移动端浏览器touch事件的研究总结
$("body").on("touchstart", function(e) { e.preventDefault(); startX = e. ...
- 「移动端」Web页面适配
一.什么是移动端适配 移动端 Web 页面,就是常说的手机 h5页面.webview页面.公众号开发的网页等. 由于手机机型较多,各个手机的屏幕尺寸不一样,所以做移动端页面,需要考虑在安卓和ios的各 ...
随机推荐
- 官宣.NET 6 预览版4
我们很高兴发布 .NET 6 Preview 4.我们现在大约完成了 .NET 6 发布的一半.现在是一个很好的时机,可以再次查看.NET6的完整范围.许多功能都接近最终形式,而其他功能将很快推出,因 ...
- postgresql分组后获取第一条数据
-- 根据编号分组取第一条数据 select * from table t where t.no=(select max(no) from table t1 where t1.no=t.no) -- ...
- 5.Java流程控制
所有的流程控制语句都可以相互嵌套.互不影响 一.用户交互Scanner Scanner对象 之前我们学的基本语法中我们并没有实现程序和人的交互,但是Java给我们提供了这样一个工具类,我们可以获取用户 ...
- asp.net 网页图片URL
"upload/"+Eval("kemu")+"/"+Eval("tx")+".jpg" " ...
- 常见数据库SELECT结果只显示前几条记录方法汇总
常见数据库SELECT结果只显示前几条记录方法汇总 为了查看数据表中的数据情况.经常会遇到想让查询结果只显示N行,比如只显示10行的情况.不同的数据库有不同的关键字和SELECT实现语法. 1.SQL ...
- GDB常用命令整理
(gdb) break xxx (gdb) b xxx 在源代码指定的某一行设置断点,其中 xxx 用于指定具体打断点的位置. (gdb) run (gdb) r 执行被调试的程序,其会自动在第一个断 ...
- java并发编程基础——线程相关的类
线程相关类 java还为线程安全提供了一些工具类. 一.ThreadLocal类(Thread Local Variable) ThreadLocal类,是线程局部变量的意思.功用非常简单,就是为每一 ...
- 环境变量PATH还原方法
修改/root/.bashrc 如果已经修改了,会出现什么问题?root用户shell找不到类似vi的命令,ls,export命令全部失效,如何去做? 以绝对路径的vi工具去删除错误的配置,然后退出再 ...
- Oracle19c 如何用rman duplicate 克隆一个数据库。(Backup-Based, no achive log)
Oracle19c 如何用rman duplicate 克隆一个数据库. 首先克隆有两种方法,一种是Backup-Based,一种是Active方式.官网文档链接https://docs.oracle ...
- React refs 的理解
一.是什么 Refs 在计算机中称为弹性文件系统(英语:Resilient File System,简称ReFS) React 中的 Refs提供了一种方式,允许我们访问 DOM节点或在 render ...