我需要一些关于 javascript 工具提示的帮助。我下面的代码在悬停时效果很好,但我不能把函数放在外面,所以可以通过点击来调用它。在函数中,只有用于计算工具提示位置及其出现方式的东西,并且有效。
非常感谢您的帮助。
var targets = $( '[rel~=tooltip]' ),
target = false,
tooltip = false,
title = false;
targets.on( 'mouseenter', function()
{
target = $( this );
tip = target.attr( 'title' );
tooltip = $( '<div id="tooltip"></div>' );
if( !tip ) {
return false;
}
target.removeAttr( 'title' );
tooltip.css( 'opacity', 0 )
.html( tip )
.appendTo( 'body' );
var init_tooltip = function()
{
containerList = $('.container').find('.listImages');
if( containerList.width() < tooltip.outerWidth() * 1.5 )
tooltip.css( 'max-width', containerList.width() / 2);
else
tooltip.css( 'max-width', 340 );
var pos_left = target.offset().left + ( target.outerWidth() / 2 ) - ( tooltip.outerWidth() / 2 ),
pos_top = target.offset().top + target.outerHeight(),
pos_right = target.offset().right + ( target.outerWidth() / 2 ) - ( tooltip.outerWidth() / 2 );
console.log(pos_right)
if( pos_left < containerList.offset().left )
{
pos_left = target.offset().left;
tooltip.addClass( 'left' );
}
else {
tooltip.removeClass( 'left' );
}
if( pos_left + tooltip.outerWidth() > containerList.offset().left + containerList.width() )
{
pos_left = target.offset().left - tooltip.outerWidth() + target.outerWidth();
tooltip.addClass( 'right' );
}
else {
tooltip.removeClass( 'right' );
}
if( pos_top < 0 )
{
var pos_top = target.offset().top + target.outerHeight();
tooltip.addClass( 'top' );
}
else {
tooltip.removeClass( 'top' );
}
tooltip.css( { left: pos_left, top: pos_top } )
.animate( { top: '+=10', opacity: 1 }, 50 );
};
init_tooltip();
$( window ).resize( init_tooltip );
var remove_tooltip = function()
{
tooltip.animate( { top: '-=10', opacity: 0 }, 50, function()
{
$( this ).remove();
});
target.attr( 'title', tip );
};
target.bind( 'mouseleave', remove_tooltip );
});