博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Touchmove获取当前触摸的Dom节点
阅读量:5748 次
发布时间:2019-06-18

本文共 1058 字,大约阅读时间需要 3 分钟。

原文链接:https://www.jianshu.com/p/a2a41fe20790

Touchmove获取当前触摸的Dom节点

近期为自己的app增加一个通讯录首字母导航的功能,如下图蓝色框部分,需求很好理解,在手指触摸相应字母时,通讯录自动滚动到相应首字母的联系人。

 
image.png

这边通过需求分析,很容易联想到,使用touchstart和touchmove这两个方法来处理响应操作,touchstart比较简单就不说了,监听touchmove事件时,发现一个问题,当我无论如何在监听元素上移动我的手指,所返回的event.touches[0].target永远指向第一个触摸元素的event对象,而不会指向我当前手指所触摸的元素。

这也就意味着我无法通过回调返回的event来获取当前手指触摸的元素

通过查阅资料,这是普遍存在的问题,最推荐的解决方案是使用

elementFromPoint

语法:
getMyElement = document.elementFromPoint ( myX , myY )
参数:
myX :  必选项。整数(Integer)。单位:象素(Pixel)。定位横坐标偏移量。
myY :  必选项。整数(Integer)。单位:象素(Pixel)。定位纵坐标偏移量。
返回值:
getMyElement :  对象(Element)。返回当前文档上处于指定坐标位置最顶层的Dom元素。

我们通过touchmove事件返回的event对象,可以获取当前手指触摸元素的clientX和clientY的值,将值传入document.elementFromPoint就可获取当前触摸的值,这里需要注意的是此方法返回的是最顶层的Dom,所以务必将你需要的Dom的z-index设置为最高,分享些许我在此项目的核心代码:

/***获取存储当前Dom位置的对象**/var myLocation = e.originalEvent.changedTouches[0];/** *取clientX及clientY并传入elementFromPoint获取当前手指触摸的Dom,大功告成,现在此Dom可以任你摆布了 **/ var realTarget = document.elementFromPoint(myLocation.clientX, myLocation.clientY);

转载于:https://www.cnblogs.com/ones/p/9340416.html

你可能感兴趣的文章
匿名函数function前面的! ~等符号作用小解
查看>>
VC模拟鼠标的两种方式(SendMessage、mouse_event)
查看>>
react-router与react-router-dom使用时的区别
查看>>
bzoj 1634: [Usaco2007 Jan]Protecting the Flowers 护花
查看>>
java调用第三方包的例子
查看>>
ssm整合快速入门程序(三)之Data类型转换器
查看>>
代码d17
查看>>
内存管理原则
查看>>
Winform下KeyDown,KeyPress,KeyUp事件的总结
查看>>
android 一个TextView设置多种颜色
查看>>
mod_rewrite
查看>>
Hadoop相关知识整理系列之一:HBase基本架构及原理
查看>>
[C++] C语言及C++语言中包含的头文件名称,及作用
查看>>
Redis实战(一)
查看>>
动态绑定下拉列表
查看>>
java中间件
查看>>
附加有文件流(FileStream)的SQL SERVER数据库文件
查看>>
移动端,input输入框被手机输入法解决方案
查看>>
POJ2524 Ubiquitous Religions(并查集)
查看>>
PAT1130 Infix Expression(树的递归)
查看>>