Jquery:隐藏顶部菜单,暂停鼠标移动时向上滑动

发布于 2024-12-11 02:17:03 字数 177 浏览 3 评论 0原文

我正在创建一个标题菜单,当您在浏览器窗口中移动鼠标时,该菜单会向下滑动。

但我想让它在鼠标5秒没有移动后向上滑动。

这是我到目前为止所拥有的: http://jsfiddle.net/BEzbw/

I'm creating a header menu that slides down when you move the mouse within in the browser window.

But I want to have it slide up after the mouse hasn't moved for 5 seconds.

Here is what I have so far: http://jsfiddle.net/BEzbw/

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

时光无声 2024-12-18 02:17:03

jQuerythrottle/debounce 是一个很棒的插件,可以安全地执行此类操作。 jsFiddle

$('html').mousemove( $.debounce( 250, true, function(e){
        $('header').animate({ top: '0' }, 300)
    }))
    .mousemove( $.debounce( 5000, false, function(e){
        $('header').animate({ top: '-60px' }, 300)
    }));

ps:请记住,附加到 中方式可能会让您的事件被其他页面元素阻止(尽管对于 mousemove 事件来说不太可能)。

jQuery throttle/debounce is a great plugin for doing things like this safely. jsFiddle

$('html').mousemove( $.debounce( 250, true, function(e){
        $('header').animate({ top: '0' }, 300)
    }))
    .mousemove( $.debounce( 5000, false, function(e){
        $('header').animate({ top: '-60px' }, 300)
    }));

ps: bear in mind that attaching to <html> in that way could get your event blocked by other page elements (although unlikely for a mousemove event).

星軌x 2024-12-18 02:17:03

尝试一下

http://jsfiddle.net/lastrose/BEzbw/3/

可能需要不过要注意时间安排

give this a try

http://jsfiddle.net/lastrose/BEzbw/3/

might need to work on the timing though

总以为 2024-12-18 02:17:03

像这样的东西吗?

$(document).ready( function () {

    $('header').css('top', '-60px');
    $('html').mousemove(function(event) {
        $('header').animate({ top: '0' }, 300);
    });

    //Increment the idle time counter every second.
    idleTime = 0;
    var idleInterval = setInterval("timerIncrement()", 6000);

    //Zero the idle timer on mouse movement.
    $(this).mousemove(function (e) {
        idleTime = 0;
    });
    $(this).keypress(function (e) {
        idleTime = 0;
    });

    function timerIncrement() {
        idleTime = idleTime + 1;
        if (idleTime > 4) { // 5sec
            $('header').animate({ top: '-60px' }, 300);
        }
    }

});

Something like this?

$(document).ready( function () {

    $('header').css('top', '-60px');
    $('html').mousemove(function(event) {
        $('header').animate({ top: '0' }, 300);
    });

    //Increment the idle time counter every second.
    idleTime = 0;
    var idleInterval = setInterval("timerIncrement()", 6000);

    //Zero the idle timer on mouse movement.
    $(this).mousemove(function (e) {
        idleTime = 0;
    });
    $(this).keypress(function (e) {
        idleTime = 0;
    });

    function timerIncrement() {
        idleTime = idleTime + 1;
        if (idleTime > 4) { // 5sec
            $('header').animate({ top: '-60px' }, 300);
        }
    }

});
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文