启用jquery slideToggle()可以处理来自一段时间的多个输出

时间:2014-02-11 18:15:07

标签: php jquery css

我在php中有以下代码,我试图为每个YouTube视频演示应用jquery slideToggle()。我的问题是jquery slideToggle()仅适用于我在while语句中的第一个youtube视频演示。其余的人都没有工作。知道如何解决这个问题吗?

<style>
#flip
{
padding:0px;
}

#panel
{
width:475px;
margin-left:3px;
margin-bottom:5px;
padding:4px;
display:none;
box-shadow: 0 0 20px rgba(0, 30, 10, 2.8);
-webkit-box-shadow: 0 0 20px rgba(0, 10, 0, 2.8);
-moz-box-shadow: 0 0 20px rgba(0, 10, 0, 2.8);
background-color:#363636;
}   
</style>


<script>
$(document).ready(function(){
    $("#flip").click(function(){
    $("#panel").slideToggle("slow");
  });
});
</script>


<?php

// above code

//next starts the while and outputs from my table all rows that contains users posts
// my code outputs all youtube links in a presentation format

while(){    


 $row['comment'] = preg_replace("/\s*[a-zA-Z\/\/:\.]*youtube.com\/watch\?v=([a-zA-Z0-9\-_]+)([a-zA-Z0-9\/\*\-\_\?\&\;\%\=\.]*)/i", "</br>

<div id='panel'>
<object width=\"0px;\" height=\"0px;\">
    <param name=\"movie\" value=\"http://www.youtube.com/v/$1&hl=en&fs=1\"></param>
    <param name=\"allowFullScreen\" value=\"true\"></param>
    <embed src=\"http://www.youtube.com/v/$1&hl=en&fs=1?&autoplay=1\" type=\"application/x-shockwave-flash\" allowfullscreen=\"true\" width=\"475px;\" height=\"260px;\"></embed>
</object>       
</div>

 <table style='border:1px solid lightgrey;'>
 <td bgcolor='#EBEBEB' style='vertical-align:top;'>                 
   <div id='flip' style='cursor:pointer;'>
   <div id='container'><div id='img1'><img src='http://img.youtube.com/vi/$1/default.jpg'/></div><div id='img2'><img src='img/play-button.png' style='width:40px; height:40px;'/> </div></div>
   </div>
 </td>

 <td width='355px;' bgcolor='#EBEBEB' style='vertical-align:top;'>
  <font color='#363636'><b>$video_title</b></font><font color='#545454'></br><a href='http://www.youtube.com/watch?v={$id}' target='_blank'><font color='#69aa35'><b>Youtube.com</b></font></a> - $video_perigrafh...</font><font color='#949494'>[$view_count views]</font>
 </td>
 </table>", $row['comment']);


 }
?>

1 个答案:

答案 0 :(得分:2)

您正在使用ID(#panel),而id应该是唯一的。选择器基于本机GetElementByID,它返回第一个匹配。

您应该使用类(<div class="panel">)代替。

http://jsfiddle.net/gLXLr/ - id与类定位的说明

编辑:关于带有类的新代码,如果您的HTML是:

<div class='panel'>
    ...
</div>
<table style='border:1px solid lightgrey;'>
    <tr>
        <td bgcolor='#EBEBEB' style='vertical-align:top;'>
            <div class='flip' style='cursor:pointer;'>
                ..
            </div>
        </td>
    </tr>
</table>

切换的代码应为:

$(document).ready(function(){
    $(".flip").click(function() {
        $(this).parents('table').prev('.panel').slideToggle("slow");
    });
});

当然,您可以根据自己的需要进行调整。