0

我有旋转的 jQuery 选项卡,当您将鼠标悬停在它们上时我想暂停它并在您单击时停止旋转。

但是,虽然暂停工作正常,但我无法取消绑定悬停事件(甚至分别取消绑定 mouseenter 和 mouseleave)。

我在这里用两种不同的方法创建了两个 jsfiddles,它们都有同样的问题。

http://jsfiddle.net/bdrvC/15/

function tab_hover_in() {
        $(this).tabs('rotate', 0, false);
}
function tab_hover_out() {
        $(this).tabs('rotate', 3000, false);
}
function tab_click() {
        $(this).tabs('rotate', 0, false);
        $(this).unbind('mouseenter',tab_hover_in);
        $(this).unbind('mouseleave',tab_hover_out);
        event.preventDefault();  
}

$('.tabs-rotate').tabs({
        selected: 'tabs-1'
}).tabs('rotate', 3000, false);

$('.tabs-rotate').bind({
        'click': tab_click,
        'mouseenter': tab_hover_in,
        'mouseleave': tab_hover_out
});

http://jsfiddle.net/bdrvC/16/

$('.tabs-rotate').tabs({
  selected: 'tabs-1'
}).tabs('rotate', 3000, false);

$('.tabs-rotate').hover(function() {
    $(this).tabs('rotate', 0, false);
  }, function() {
    $(this).tabs('rotate', 3000, false);
});
$('.tabs-rotate').click(function() {

  $(this).tabs('rotate', 0, false);
  $(this).unbind('mouseleave');

});

谁能解释为什么即使在点击后旋转仍在继续?

非常感谢!

4

1 回答 1

1

您的点击事件未绑定到正确的元素...您可以使用

$('.ui-tabs-nav li a').click(function() {...});

反而

于 2012-11-06T14:38:07.597 回答