只做实现。。完全没考虑性能优化。所以我实现了以后特别卡。

 

第一个是在通讯录右边的索引条上进行滑动,滑动到相应字母就跳转到相应字母的锚点上。

思路:监听touchmove事件,获取clientX和clientY,传入到elementFromPoint,然后获取到元素以后执行click()即可。

这里会有个问题,就是如果你的页面中有遮罩层这一类的顶层元素的话,请将其pointer-events:none,就算这个元素的display:none;也没用,实践出真知。可以去试下。

index为索引div的id

1  $("#index").get(0).addEventListener('touchmove',function(event){
2          var a = document.elementFromPoint(event.touches[0].clientX,event.touches[0].clientY).parentNode;
3          a.click();
4      });
5     
示例代码

相关文章: