zoukankan      html  css  js  c++  java
  • Touchmove获取当前触摸的Dom节点

    原文链接: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);
  • 相关阅读:
    Linux常用操作命令总结
    Centos7安装FastDFS教程
    Permutation Sequence
    Next Permutation
    Remove Element
    4Sum
    3Sum Closest
    3Sum
    Longest Consecutive Sequence
    Median of Two Sorted Arrays
  • 原文地址:https://www.cnblogs.com/ones/p/9340416.html
Copyright © 2011-2022 走看看