我制作了自己的小工具提示,但是当我走得太快时似乎出现了问题。
这是一个简单的工具提示,即鼠标输入,它会向您显示一个在顶部淡入并带有一些文本的气泡,鼠标离开气泡淡出。
当在几个不同的元素上非常快速地执行 mouseenter/mouseleave 时会出现问题......首先它开始只褪色到 0.6,然后最终不显示。
我猜这与排队有关。所以我尝试了 stop() 和 clearqueue() 但它仍然不起作用。
这是插件:
(function ($) {
$.fn.tooltip = function (options) {
var selector = $(this).selector;
var defaults = {
fadeInSpeed:350,
fadeOutSpeed:200,
delayIn: 350,
delayOut: 300,
popupId:'tooltip_popup',
verticalOffset: 30
};
var settings = $.extend({}, defaults, options);
$(document).delegate(selector, 'mouseenter', function (e) {
var $this = $(this);
var title = $this.attr('title');
$this.attr('title', '');
if (title !== '') {
if ($('#' + settings.popupId).text() === '') {
$('<div />').attr('id', settings.popupId)
.appendTo('body')
.css({
position:'absolute',
backgroudColor: 'black',
zIndex: 5
})
.addClass('tooltip_style')
.hide();
$('<div />').appendTo('#' + settings.popupId).addClass('tooltip_arrow');
$('<span />').appendTo('#' + settings.popupId);
} else {
$('#' + settings.popupId).hide().stop().clearQueue().hide();
}
var ele_x = $this.offset().left;
var ele_y = $this.offset().top;
$('#' + settings.popupId+' span').text(title);
$('#' + settings.popupId)
.css({
top : ele_y - settings.verticalOffset,
left: ele_x
})
.delay(settings.delayIn)
.fadeIn(settings.fadeInSpeed);
}
});
$(document).delegate(selector, 'mouseleave', function (e) {
var $this = $(this);
$('#' + settings.popupId)
.delay(settings.delayOut)
.fadeOut(settings.fadeOutSpeed);
$this.attr('title', $('#' + settings.popupId+' span').text() );
});
return this;
}
})(jQuery);
您可能会注意到,我认为这一行是我需要修复的:
$('#' + settings.popupId).hide().stop().clearQueue().hide();
(这有点乱,因为我正在尝试一切......哈)。
我认为我不太了解排队的事情。
这是一个小提琴:http: //jsfiddle.net/denislexic/7YMcu/2/
谢谢你的帮助。