Как запустить событие mouseover, только если мышь зависла над элементом не менее 1 секунды?

Я хочу отобразить диалоговое окно, когда пользователь наводит курсор на определенное изображение. Эта часть работает. К сожалению, если мышь даже просто проходит над углом изображения быстро, она отобразит диалоговое окно. Я хотел бы, чтобы диалоговое окно отображалось только в том случае, если мышь остается над изображением в течение одной полной секунды, чтобы избежать непреднамеренных всплывающих окон.

Я видел этот вопрос но это для jQuery, и я использую Prototype. Я не знаю достаточно jQuery, чтобы интерпретировать, что решение.

Если бы кто-то мог объяснить логику или функциональность JavaScript, которая потребуется, чтобы вызвать отложенный запуск события mouseover, я был бы признателен.

4 ответов


вы не можете отложить запуск события, но вы можете отложить обработку события.

вот быстрый пример без jQuery или прототипа, который облегчит его понимание.

var delay = function (elem, callback) {
    var timeout = null;
    elem.onmouseover = function() {
        // Set timeout to be a timer which will invoke callback after 1s
        timeout = setTimeout(callback, 1000);
    };

    elem.onmouseout = function() {
        // Clear any timers set to timeout
        clearTimeout(timeout);
    }
};


delay(document.getElementById('someelem'), function() {
    alert("Fired");
});

проверьте hoverintent http://cherne.net/brian/resources/jquery.hoverIntent.html он будет делать именно то, что вы хотите.

Я обычно не размещаю ссылки на ответы, но он прост в использовании и было бы хорошо прочитать его и узнать.


я вдохновлен Робертом (спасибо) и для загрузки данных из таблицы я использую это:

<tr onmouseover="funcDelay= setTimeout('loadData(5)', 1000)" onmouseout="clearTimeout(funcDelay)">

и функция для загрузки данных

function fLoadDatDetail(vZadId) {
  $("#divId").load("/controller/function/"+vZadId);
}

вы должны держать мышь 1 секунду над одной строкой <TABLE>, чтобы получить подробную информацию о нем.


логика такова:

когда мышь перемещается по объекту, создается таймер, который будет срабатывать через 1000 миллисекунд. Когда мышь удаляется от объекта, если таймер еще не запущен, таймер отключается и удаляется из памяти, предотвращая его запуск.