近期为自己的app增加一个通讯录首字母导航的功能,如下图蓝色框部分,需求很好理解,在手指触摸相应字母时,通讯录自动滚动到相应首字母的联系人。
这边通过需求分析,很容易联想到,使用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);