JQuery Показать скрыть класс при зависании
Я относительно новичок в JQuery, и я хотел бы иметь возможность отображать меню для мыши.
Вот html
<td class ="comment_div"> <?php echo("$comment_data['comment']); ?> <br/>
<span class="comment_actions"> Approve | Delete | Spam | Edit</span>
</td>
Затем JQuery
$("comment_div").hover(
function() { $(".comment_actions").show(); },
function() { $(".comment_actions").hide(); }
);
Это работает, за исключением того, что я вынимаю несколько комментариев, и это только покажет меню в первом div, независимо от того, какой "комментарий" является hoverd. Я хотел бы, чтобы меню отображалось только для комментария, который в настоящее время находится на вершине. Я думаю, мне нужно использовать "$ this", чтобы выполнить эту работу, но не знаю, как это сделать.
Спасибо.
Ответы
Ответ 1
Если я правильно читаю, формат должен быть -
$(".comment_div").hover(
function() { $(this).children(".comment_actions").show(); },
function() { $(this).children(".comment_actions").hide(); }
);
Отредактируйте, потому что я полный идиот.
Ответ 2
Что-то вроде этого работает для меня:
<script>
$(document).ready(function() {
$(".container").hover(
function() { $(this).children('.comment_actions').show(); },
function() { $(this).children('.comment_actions').hide(); }
);
});
</script>
<style>
</style>
<table border="1"><tr>
<td class ="container"><br/>
asd<span class="comment_actions">Approve | Delete</span>
</td>
<td class ="container"><br/>
asd <span class="comment_actions">Approve | Delete</span>
</td>
<td class ="container"><br/>
asd<span class="comment_actions"> Approve| Delete</span>
</td>
</tr></table>
Тем не менее, проблема, с которой вы столкнетесь, - это действия наведения над div, который имеет отображение: none; задавать. Возможно, вам стоит рассмотреть возможность его переноса в то, что чувствительна к мыши, а затем отображать/скрывать детей.