我有一些动态生成的HTML:
<label class="passiveText smallText" title="Name: Smith, John , Occupation Code: BA81, Occupation
Description: BUSINESS SYSTEMS M" rel="tooltip" style="margin-top:10px; width:80%; text-decoration:underline;
color:#009245;" containeridx="0" id="lblBadge_7022_0">7022</label>
现在我有一个jQuery函数,当点击时会出现工具提示:
$( function()
{
var targets = $( '[rel~=tooltip]' ),
target = false,
tooltip = false,
title = false;
targets.bind( 'click', function()
{
target = $( this );
tip = target.attr('title');
tooltip = $( '<div id="tooltip"></div>' );
if( !tip || tip == '' )
return false;
tooltip.css( 'opacity', 0 )
.html( tip )
.appendTo( 'body' );
var init_tooltip = function()
{
if( $( window ).width() < tooltip.outerWidth() * 1.5 )
tooltip.css( 'max-width', $( window ).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 - tooltip.outerHeight() - 20;
if( pos_left < 0 )
{
pos_left = target.offset().left + target.outerWidth() / 2 - 20;
tooltip.addClass( 'left' );
}
else
tooltip.removeClass( 'left' );
if( pos_left + tooltip.outerWidth() > $( window ).width() )
{
pos_left = target.offset().left - tooltip.outerWidth() + target.outerWidth() / 2 + 20;
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 );
tooltip.bind( 'click', remove_tooltip );
});
});
它没有做的就是像我想的那样切换。我想要的是当工具提示启动时,再次点击它我希望工具提示消失。
我怎样才能做到这一点?
答案 0 :(得分:0)
我发现这是我的解决方案:
$(function () {
var targets = $('[rel~=tooltip]');
targets.on('click', function () {
var $this = $(this);
var tooltip = $this.children('#tooltip');
if (tooltip.length > 0) {
tooltip.remove();
return true;
}
tooltip = $('<div id="tooltip">');
tooltip.text($this.attr('title'));
var init_tooltip = function () {
if ($(window).width() < tooltip.outerWidth() * 1.5)
tooltip.css('max-width', $(window).width() / 2);
else
tooltip.css('max-width', 340);
var pos_left = $this.offset().left + ($this.outerWidth() / 2) - (tooltip.outerWidth() / 2),
pos_top = $this.offset().top - tooltip.outerHeight() - 20;
if (pos_left < 0) {
pos_left = $this.offset().left + $this.outerWidth() / 2 - 20;
tooltip.addClass('left');
}
else
tooltip.removeClass('left');
if (pos_left + tooltip.outerWidth() > $(window).width()) {
pos_left = $this.offset().left - tooltip.outerWidth() + $this.outerWidth() / 2 + 20;
tooltip.addClass('right');
}
else
tooltip.removeClass('right');
if (pos_top < 0) {
var pos_top = $this.offset().top + $this.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);
$this.append(tooltip);
});
});