我遇到了一个奇怪的问题。
如果鼠标被移动,jQuery 1.4.1 mouseenter/mouseleave 事件会正确触发,没什么大不了的。但是,当光标本身保持静态但元素被 animate() 移开时,它在某些浏览器中会出错。
所以想象一下这样的代码:
jQuery('somelement').bind(
{
mouseenter: function(e) {
log.debug("enter");
$(this).animate({left: 9999}, 2000);
},
mouseleave: function() {
log.debug("leave");
}
});
如果您将鼠标快速移动到元素上然后停止它,您将获得不同的结果,具体取决于浏览器。
FF3.6、Safari 4、IE7:当光标离开动画元素时,mouseleave 按预期触发,即使鼠标本身静止不动。
IE6、IE8、Opera 9/10、Safari 3、Chrome:即使元素在窗口之外,也不会触发 mouseleave。需要稍微移动鼠标来触发正确的 mouseleave 事件。
任何想法如何解决它?