我使用的是在这里找到的代码版本
var startTime, endTime;
document.getElementById(queryid).addEventListener('touchstart',function() {
startTime = new Date().getTime();
},false);
document.getElementById(queryid).addEventListener('touchend',function(event) {
endTime = new Date().getTime();
if((endTime-startTime) > 1000)
alert('tap hold event');
},false);
它在某些操作之前执行点击并按住的“技巧”,但我的问题是只有当我停止触摸屏幕时才会触发操作,而我希望在点击至少 1 秒后触发操作,无论我是否停止触摸屏幕与否..
这个似乎更接近我想要的,但它似乎并不完整..(据我了解.. gbStillTouching 总是错误的?我看不到任何地方被切换.. gnstarttime ==nid?不是 nid=gnstarttime ?
var gnStartTime = 0;
var gbMove = false;
var gbStillTouching = false;
function checkTapHold(nID) {
if ((!gbMove) && (gbStillTouching) && (gnStartTime == nID)) {
gnStartTime = 0;
gbMove = false;
alert('tap hold event');
}
}
window.addEventListener('touchstart',function(event) {
gnStartTime = Number(new Date());
setTimeout('checkTapHold(' + gnStartTime + ');clearTimeout();',2000);
},false);
window.addEventListener('touchmove',function(event) {
gbMove = true;
},false);
window.addEventListener('touchend',function(event) {
gbStillTouching = false;
},false);