У меня есть динамическая таблица, загруженная ajax. Я хочу показать всплывающую подсказку, когда я наводил указатель мыши на строку, но я хочу, чтобы всплывающая подсказка отображалась над определенной ячейкой (с классом .name
), а не над всей строкой.
Кроме того, используя функцию заголовка, мне нужно иметь возможность получить идентификатор ближайшего номера и вернуть настраиваемый шаблон.
Вот мой код:
<table class="table" id="myTable">
<thead>
<tr>
<th>ID</th>
<th>Name</th>
<th>Country</th>
<th>Statistics</th>
</tr>
</thead>
<tbody>
<tr id="1">
<td >1</td>
<td class="name">Name #1</td>
<td>United States of America</td>
<td>100%</td>
</tr>
<tr id="2">
<td >2</td>
<td class="name">Name #2</td>
<td>United States of America</td>
<td>50%</td>
</tr>
</tbody>
</table>
Инициализация:
$('#myTable').tooltip({
container: 'body',
html: true,
selector: 'td.name',
trigger: 'manual',
title: function() {
// here will be custom template
var id = $(this).parent().atrr('id');
return id;
}
});
Попытка одна: Демо в jsFiddle
$('#myTable')
.on('mouseenter focusin', 'tbody > tr', function() {
$(this).find('td.name').tooltip('show');
})
.on('mouseleave focusout', 'tbody > tr', function() {
$(this).find('td.name').tooltip('hide');
});
Попытка вторая: Демо в jsFiddle
var tip;
$('#myTable')
.on('mouseenter focusin', 'tbody > tr', function() {
tip = $(this).find('.offer-name');
tip.tooltip(hereAllTooltipOptions);
tip.tooltip('show');
})
.on('mouseleave focusout', 'tbody > tr', function() {
tip.tooltip('hide');
});
Но я очень удивляюсь выполнению такого решения. Итак, вопрос в том, как это сделать и сделать это лучше?