我有一个带有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();
});
});
任何只在每一行显示消息的解决方案?
答案 0 :(得分:2)
尝试更改:
var sh = $('.tansa');
var sharrow = $('.arrow');
为:
var sh = $(this).siblings('.tansa');
var sharrow = $(this).siblings('.arrow');
(以及等效的shs和sharrows变量)。您的代码使用this
引用具有特定类的所有元素,而不是相对于正在悬停的元素的那些元素。
<强> jsFiddle example 强>