使用 Jquery 在 Ipad 中双击

Posted

技术标签:

【中文标题】使用 Jquery 在 Ipad 中双击【英文标题】:Doubletap in Ipad using Jquery 【发布时间】:2015-08-01 10:08:08 【问题描述】:

我的任务是当我双击我的内容时从 ipad 发出警报。我使用此代码检查我的双击

(function($)
// Determine if we on iPhone or iPad
var isios = false;
var agent = navigator.userAgent.toLowerCase();
if(agent.indexOf('iphone') >= 0 || agent.indexOf('ipad') >= 0)
       isiOS = true;


$.fn.doubletap = function(onDoubleTapCallback, onTapCallback, delay)
    var eventName, action;
    delay = delay == null? 500 : delay;
    eventName = isiOS == true? 'touchend' : 'click';

    $(this).bind(eventName, function(event)
        var now = new Date().getTime();
        var lastTouch = $(this).data('lastTouch') || now + 1 /** the first time this will make delta a negative number */;
        var delta = now - lastTouch;
        clearTimeout(action);
        if(delta<500 && delta>0)
            if(onDoubleTapCallback != null && typeof onDoubleTapCallback == 'function')
                onDoubleTapCallback(event);
            
        else
            $(this).data('lastTouch', now);
            action = setTimeout(function(evt)
                if(onTapCallback != null && typeof onTapCallback == 'function')
                    onTapCallback(evt);
                
                clearTimeout(action);   // clear the timeout
            , delay, [event]);
        
        $(this).data('lastTouch', now);
    );
;)(jQuery);

我从我的页面调用此代码

$(".selector").doubletap(
/** doubletap-dblclick callback */
function(event)
    alert('double-tap');
,
/** touch-click callback (touch) */
function(event)
    alert('single-tap');
,
/** doubletap-dblclick delay (default is 500 ms) */
400);

它可以在我的桌面上运行。但是当我在 ipad 中打开它时,它无法正常运行。请给我一些解决方案

【问题讨论】:

【参考方案1】:

最后我使用了这段代码。

var elm1 = document.getElementById('test1');
var elm2 = document.getElementById('test2');
var timeout;
var lastTap = 0;
elm1.addEventListener('touchend', function(event) 
var currentTime = new Date().getTime();
var tapLength = currentTime - lastTap;
clearTimeout(timeout);
if (tapLength < 500 && tapLength > 0) 
    elm2.innerhtml = 'Double Tap';
    event.preventDefault();
 else 
    elm2.innerHTML = 'Single Tap';
    timeout = setTimeout(function() 
        elm2.innerHTML = 'Single Tap (timeout)';
        clearTimeout(timeout);
    , 500);

lastTap = currentTime;
); 

【讨论】:

以上是关于使用 Jquery 在 Ipad 中双击的主要内容,如果未能解决你的问题,请参考以下文章

使用java在android中双击问题

CircularProgressLayout 没有在 Espresso 中双击

在iOS中双击图像不放大

如何防止在PhoneGap中双击移动滚动?

如何在资源管理器中双击文件被钩住?

强制在代码中双击