php - 启用 jquery slideToggle() 用于一段时间内的多个输出

标签 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']);


 }
?>

最佳答案

您正在使用一个 id (#panel) 并且 id 应该是唯一的。选择器基于 native 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");
    });
});

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

关于php - 启用 jquery slideToggle() 用于一段时间内的多个输出,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21709820/

相关文章:

php - SQL百分比查询

javascript - 如何在图像上放置很棒的字体并模仿悬停属性

Javascript ES6 HTML5 Canvas 图像未绘制到背景 Canvas 或背景 Canvas 未显示

javascript - 一旦达到某个最高值,删除具有几乎相同 id 的 div

php - MySql : can i query "WHERE ' $str' LIKE %table. col%"?

php - setValueBinder 在使用 maatwebsite/laravel-excel 时单张 excel 时不起作用

javascript - 如何正确回显 onclick ='function($var)'

javascript - Bootstrap 日期分页器 日期选择器

javascript - Angularjs - 文本区域自动增长

Javascript 变音符号不敏感搜索