0

我有一个带有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();
  });
});

任何解决方案仅在每一行中显示消息?

4

1 回答 1

2

尝试改变:

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

到:

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

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

jsFiddle 示例

于 2012-09-07T03:42:18.987 回答