我有以下功能,在某些div(#block_profile)上执行qtip2工具提示,问题是它被多次触发。所以,如果我点击第4个#block_profile,它会调用此函数4次。我怎样才能使它只执行已被点击的确切div?
// Create the tooltips only on document load
$(document).ready(function () {
// Make sure to only match links to wikipedia with a rel tag
$('div.block_profile[rel]').each(function () {
// We make use of the .each() loop to gain access to each element via the "this" keyword...
$(this).qtip(
{
content:{
// Set the text to an image HTML string with the correct src URL to the loading image you want to use
text:'<img src="/assets/ux/modal/loading.gif" alt="Loading..." />',
ajax:{
url:'/profiles/get_info/' + $(this).attr('rel') // Use the rel attribute of each element for the url to load
},
title:{
button:false
}
},
position:{
my:'top left',
target: 'mouse',
viewport:$(window), // Keep the tooltip on-screen at all times
adjust:{
x:10, y:10
}
},
hide:{
fixed:false // Helps to prevent the tooltip from hiding ocassionally when tracking!
},
style:{
classes:'container ui-tooltip ui-tooltip-tip'
}
})
})
// Make sure it doesn't follow the link when we click it
.click(function (event) {
event.preventDefault();
});
});
html:
<div id ="block_profile" class ="block_profile rel="1">div 1</div>
<div id ="block_profile" class ="block_profile rel="2">div 2</div>
<div id ="block_profile" class ="block_profile rel="3">div 3</div>
<div id ="block_profile" class ="block_profile rel="4">div 4</div>
<div id ="block_profile" class ="block_profile rel="5">div 5</div>
答案 0 :(得分:1)
您应该使用以下代码:
// Create the tooltips only on document load
$(document).ready(function () {
// Make sure to only match links to wikipedia with a rel tag
$('div.block_profile[rel]')
.qtip({
...
})
.click(function (event) {
event.preventDefault();
});
});
无需each
来电。例如,请查看this demo。