gpt4 book ai didi

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

转载 作者:太空宇宙 更新时间:2023-11-04 04:03:24 25 4
gpt4 key购买 nike

我在 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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com