Подтвердить что ты не робот

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", чтобы выполнить эту работу, но не знаю, как это сделать.

Спасибо.

4b9b3361

Ответ 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; задавать. Возможно, вам стоит рассмотреть возможность его переноса в то, что чувствительна к мыши, а затем отображать/скрывать детей.