本文主要是介绍触屏touchstart 与 click,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
设计效果:当手指点击或触摸红框线menuList之外的部分时,弹框menuList消失。
问题:在优化触屏版的时候发现如图问题,当menuList弹出,手指触摸屏幕向下滑动时,menuList弹框不消失,只有手指点击menuList之外的部分才消失。
查看代码发现,源代码只定义了click事件:
$(doc.body).on('click',function(e) {if (e.target.id != 'menu') headerMenu.hide();});
说明触屏版对click和touch解析是不同的事件。
于是查了下touch的用法,发现是有touchstart,touchmove,touchend事件的,并且可以像click样直接使用。
于是更改代码:
$(doc.body).on('click touchmove',function(e) {if (e.target.id != 'menu') headerMenu.hide();});
OK,可以
更多demo和解析:http://www.aliued.cn/2013/04/27/%E7%A7%BB%E5%8A%A8%E5%BC%80%E5%8F%91%E4%B9%8Btouch-event%E7%AF%87.html
这篇关于触屏touchstart 与 click的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!