2

我有一个菜单。在这个菜单中,我有一些隐藏的子菜单,所以我在悬停动作后显示它。我对子菜单的显示也有一些延迟效果。现在我想在隐藏它时添加相同的效果。但它不起作用。另外,如何在悬停/鼠标进入下一个菜单元素上添加一些延迟?

$('.main_menu ul li').on({
    mouseenter: function(){
        var self = this,
            time = 200;
        $(self).data('timer', setTimeout(function(){
            $(self).children('.sub_menu_main').addClass('opened');
        }, time));
    },
    mouseleave: function(){
        var self = this,
            time = 200;
        clearTimeout($(self).data('timer'));
        setTimeout(function() {
            $(self).children('.sub_menu_main').removeClass('opened');
        }, time);
    }
});
4

3 回答 3

4

我很好地解决了这个问题,所以:

var timer;
$('.main_menu ul li').on({
    mouseenter: function(){
        var self = this;
        clearTimeout(timer);
        timer = setTimeout(function(){
            $(self).children('.sub_menu_main').addClass('opened');
        }, 100)
    },
    mouseleave: function(){
        var self = this;
        setTimeout(function(){
            if (!$(self).children('.sub_menu_main').is(":hover")){
                 $(self).children('.sub_menu_main').removeClass('opened');
            }
        }, 100);
    }
});
于 2013-02-13T10:31:05.593 回答
0

可能是您没有self在 mouseleave 事件中使用吗?那个this函数里有什么?发表debugger声明,看看是否this是您认为它所指的事物。

于 2013-01-16T11:13:31.540 回答
0

你考虑过使用.delay()吗?

http://api.jquery.com/delay/

于 2013-01-16T11:21:10.897 回答