cordova 开发 app 使用 touch 事件替换 click 事件
时间:2020-04-26 10:23:24|栏目:|点击: 次
使用 ul li 做导航条时,由于 click 事件的处理时机要晚于 touchstart ,并且 click 事件能明显使用户感觉到延迟,因此使用 touch 事件代替 click 事件。
由此又带来一个问题:用户滑动导航条时,本意可能是让导航条滚动,但是却触发了导航中某一项的点击事件。下面的代码使用 touchstart 与 touchmove 相结合的方式解决二者的冲突。
由此又带来一个问题:用户滑动导航条时,本意可能是让导航条滚动,但是却触发了导航中某一项的点击事件。下面的代码使用 touchstart 与 touchmove 相结合的方式解决二者的冲突。
var nav = document.querySelector(".nav");
nav.addEventListener("touchstart", function(e){
if(e.target.tagName == "LI"){
app.navTouchEventTimer = setTimeout(function(){
// 100毫秒后处理 ul.nav 内部 li 的 touch 事件
},100);
}
}, false);
nav.addEventListener("touchmove", function(e){
if(app.navTouchEventTimer != false){
// 在 ul.nav 的 touchmove 事件监听器中取消 li 的 touch 事件
clearTimeout(app.navTouchEventTimer);
app.navTouchEventTimer = false;
}
// 处理 ul.nav 的 touchmove 事件
}, false);
上一篇:Specified AAPT2 executable does not exist错误的处理
栏 目:
本文标题:cordova 开发 app 使用 touch 事件替换 click 事件
本文地址:http://www.codeinn.net/misctech/2248.html






