jquery Hover和while循环

时间:2012-09-07 03:36:54

标签: php javascript jquery

我有一个带有while循环的php表来显示记录。

我添加了一个jQuery悬停处理程序来执行此操作,如果悬停它会在同一行显示一条消息 但问题是,如果悬停它会在所有行中显示一条消息。

这是css:

<style>
  .tansa{
    position: absolute;
    margin-right: -60px;
    margin-top:-25px;
    background: #CBDFF3; border: 1px solid #4081C3; font-size: 0.88em;
    padding: 2px 7px; display: inline-block;
    border-radius: 8px; -moz-border-radius: 8px; -webkit-border-radius: 8px;
    line-height: 1.2em; 
    text-shadow: 0 0 0em #FFF;
    overflow: hidden;
    text-align: center;
    color:black;
    display:none;
  }

  .arrow{ 
    position: relative;
    width: 0;
    height: 0;
    top: -25px;
    border-top: 5px solid #000000;
    border-right: 5px solid transparent;
    border-left: 5px solid transparent;
    display:none;
  }
</style>

这是我的php:

<table><tr>row</tr>
<?php
$results = mysql_query("select * from MyTable");
while{$r = mysql_fetch_array($results)){
echo "<tr><td>Row : <img src='img/tans.png' width='24' height='24' class='tansef' /><span      class='tansa' >the message</span><div class='arrow'></div></td></tr>";
}
?>
</table>

这是jquery

$(document).ready(function(){
  $('.tansef').hover(function(){
    var sh = $('.tansa');
    var sharrow = $('.arrow');
    sh.show();
    sharrow.show();
  }, function(){
    var shs = $('.tansa');
    var sharrows = $('.arrow');
    shs.hide();
    sharrows.hide();
  });
});

任何只在每一行显示消息的解决方案?

1 个答案:

答案 0 :(得分:2)

尝试更改:

var sh = $('.tansa');
var sharrow = $('.arrow');

为:

var sh = $(this).siblings('.tansa');
var sharrow = $(this).siblings('.arrow');

(以及等效的shs和sharrows变量)。您的代码使用this引用具有特定类的所有元素,而不是相对于正在悬停的元素的那些元素。

<强> jsFiddle example