QTip2多个元素,相同的工具提示

QTip2 Multiple Elements, Same Tooltip

本文关键字:工具提示 元素 QTip2      更新时间:2023-09-26

我有一个页面,可以在其中动态创建需要工具提示的元素。

我尝试了几种不同的方法,并在网上寻找一些答案,但都无济于事。

截至目前,我有这个:

var $links = $('a.link');
var len = $links.length;
for(var i = 0; i < len; i++){
    var $ele = $($links[i]);
    $ele.qtip({
        id: 'editLink',
        overwrite: false,
        content: {
            text: $linkEditor,
            title: {
                text: 'Edit Link',
                button: true
            }
        },
        position: {
            my: 'top center',
            at: 'bottom center',
            viewport: $(window)
        },
        show: {
            event: 'mouseover',
            solo: true
        },
        hide: false,
        style: {classes: 'ui-tooltip-shadow ui-tooltip-red'}
    });
}

我正在寻找的是让所有这些元素使用完全相同的工具提示的方法。我希望它们都使用完全相同的内容(在本例中为单个表单),并以完全相同的方式引用工具提示(通过id为"ui工具提示editLink"的工具提示元素)。

根据我所拥有的,它当前正确地创建了第一个工具提示,但如果我添加一个新元素并重新分配工具提示,它会为新元素创建一个具有不同id的全新工具提示。

有人知道如何实现多个元素,相同的工具提示方法吗?

我已经想出了如何让一个工具提示div被许多工具提示图像共享,如果有人觉得它很方便的话

 $(".tooltipBearing").qtip({
                            content: {  
                                text: $("#tooltipDiv").html()
                            }          
                      });

如果您未能将.html()放在上面,您将看到共享工具提示显示一次,然后当您从另一个图像激活它时,它将不再适用于第一个图像。。。

工具提示轴承是在页面中的某些图像上设置的类。

tooltipDiv是包含工具提示内容的div的ID。

为了在动态创建的元素中使用qtip,您需要在元素初始化期间包含qtip

例如

$('<div style="top:0px; left:0px; position:absolute;">abc123</div>').appendTo("body").qtip({content: "test"});

遗憾的是,我们似乎需要为每个悬停/单击元素克隆Tooltip元素。

Craig在GitHub上提到了这一点:https://github.com/Craga89/qTip2/issues/173

这就是我所做的。我在一个独特的元素上附加了我的工具提示。然后我所有其他需要相同工具提示的元素都会触发唯一元素的工具提示显示:

$('#unique-element').qtip({
  content: {text: 'My Tooltip'},
});
$('.other-elements').click(function(){
  $('#unique-element').qtip('show');
});

但是,所有工具提示都将显示在固定位置。这在我的情况下不是问题,因为我使用工具提示作为模态。您必须通过剪切event方法来管理工具提示位置。

根据user738048的回答,我的工作解决方案如下:

$('[data-tooltipid]').each(function() {
    var ttid = $(this).data('tooltipid');
    $(this).qtip({
        content: {
            text: $('#'+ttid).html(),
        },
        position: {
            my: 'top left',
            at: 'bottom left',
            target: $(this)
        }
    }).removeAttr('href').removeAttr('onclick');
});

在我的例子中,包含文本的HTML元素的id取自data-tooltipid属性;我的hrefonclick属性将被删除,因为它们已被工具提示废弃。