簡體   English   中英

JQuery懸停功能超時

[英]JQuery Hover Function Timeout

我在SO上看過其他類似的問題,但答案並不是我想要的。 我下面的代碼的問題是關於變量hide

在它的當前形式中,第一個懸停功能不會顯示隱藏 ,但我不想在更高的范圍內聲明它,因為它在那里沒有用處。 另外,在更高的范圍內聲明它需要為每個li制作一個不同的變量。

保持這個變量在這兩個函數之間包含超時的解決方案是什么?

$('li').hover(function() {
    clearTimeout(hide);
    $('.menu', this).show();
}, function() {
    var menu = $('.menu', this);
    var hide = setTimeout(function() {
        menu.hide();
    }, 500);
});

您可以使用.data()存儲該值

$('li').hover(function() {
    clearTimeout($(this).data('hide'));
    $('.menu', this).show();
}, function() {
    var menu = $('.menu', this);
    $(this).data('hide', setTimeout(function() {
        menu.hide();
    }, 500));
});

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM