在jQuery中长按/长按事件支持/插件

时间:2012-08-27 14:51:07

标签: javascript jquery onclick touchscreen

我正在开发一个需要鼠标悬停菜单的网站。我不建议从可访问性的角度来看鼠标悬停菜单,但使用jQuery实现它很容易。

问题:我们还需要支持触摸屏设备(平板电脑)。在这样的设备上,您没有鼠标,因此鼠标悬停事件不起作用。我希望jQuery有一个longpress事件,但事实并非如此。我确实找到了使用谷歌的jQuery longclick plugin,但它适用于jQuery 1.4,所以我并不热衷于使用它。此外,jQuery插件网站目前正处于维护状态,因此不太有用。

所以问题是:是否有一个优雅的jQuery 1.7 / 1.8插件来支持longpress / longclick事件?

3 个答案:

答案 0 :(得分:6)

事实证明,你可以使用jQuery 1.8的现有longclick plugin来实现jQuery 1.4。

$("#area").mousedown(function(){
    $("#result").html("Waiting for it...");
});
$("#area").longclick(500, function(){
    $("#result").html("You longclicked. Nice!");
});
$("#area").click(function(){
    $("#result").html("You clicked. Bummer.");
});
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.8.0/jquery.min.js"></script>
<script src="http://rawgit.com/pisi/Longclick/master/jquery.longclick-min.js"></script>
    
<p id="area">Click me!</p>
<p id="result">You didn't click yet.</p>

答案 1 :(得分:4)

您可以做的事情是在各种鼠标事件期间使用setTimeout延迟检查。合并jQuery的$.data()来跨事件(在每个元素上)存储超时应该可以帮助您完成所有操作。这是一个例子:

HTML:

<ul id="menu">
    <li><a href="#" onclick="return false;" class="test"></a></li>
    <li><a href="#" onclick="return false;" class="test"></a></li>
</ul>

JS:

var mousepress_time = 1000;  // Maybe hardcode this value in setTimeout
var orig_message = "Click Here";  // Remove this line
var held_message = "Down";  // Remove this line

$(document).ready(function () {
    $(".test")
        .html(orig_message)  // Remove this line
        .on("mousedown", function () {
            console.log("#########mousedown");  // Remove this line
            var $this = $(this);
            $(this).data("checkdown", setTimeout(function () {
                // Add your code to run
                $this.html(held_message);  // Remove this line
            }, mousepress_time));
        }).on("mouseup", function () {
            clearTimeout($(this).data("checkdown"));
            console.log("#######mouseup");  // Remove this line
            $(this).html(orig_message);  // Remove this line
        }).on("mouseout", function () {
            clearTimeout($(this).data("checkdown"));
            console.log("#######mouseout");  // Remove this line
            $(this).html(orig_message);  // Remove this line
        });
});

DEMO http://jsfiddle.net/7jKYa/10/

还有很多与此相关的事情,因为你也在考虑悬停,但在大多数情况下,我认为这可以做你想要的。

如果需要,它可以很容易地转换为插件,否则我认为它可以单独工作。我希望这会有所帮助!

答案 2 :(得分:1)

你可以计时。

function onImageMouseDown(e){
    var d = new Date();
    md_time = d.getTime(); // Milliseconds since 1 Apr 1970
}

function onImageMouseUp(e){
    var d = new Date();
    var long_click = (d.getTime()-md_time)>1000;
    if (long_click){
        // Click lasted longer than 1s (1000ms)
    }else{
        // Click lasted less than 1s
    }
    md_time = 0;
}