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);
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 触摸事件: 三种在规范中列出并获得跨移动设备广泛实现的基本触摸事件: 1.touchstart:手指放在一个DOM...
    晨光2016阅读 24,522评论 0 13
  • 基于html5的移动web页面搭建技术总结 1.技术要点 1.1面向不同尺寸的手机屏幕,页面布局适配问题。 网页的...
    敲代码的张阅读 1,591评论 0 3
  • 基于html5的移动web页面搭建技术总结1.技术要点1.1面向不同尺寸的手机屏幕,页面布局适配问题。 网页的he...
    敲代码的张阅读 404评论 0 0
  • 之前的时候,舍友在宿舍看“第八号当铺”这部电视剧,我在旁边也跟着看了一点。虽然我没看全,但是也大体了解了其中的意思...
    太太太梓飞阅读 1,044评论 0 3
  • 过了一个周末,日记停了两天!今天孩子上学了,日记走起!孩子放学回家,吃过晚饭开始写作业。写完之后,照例和他...
    博博爸阅读 163评论 0 0

友情链接更多精彩内容