我在此页面上有一个在php中回显的按钮。我还回显了一个jQuery脚本,以在单击按钮时slideToggle一个ul列表元素。这里的问题是在回显按钮的同时回显了jQuery javascript脚本,我想不出任何办法来延迟它。
码:
<?php
include_once('../php/connDb.php');
mysqli_set_charset($connect, 'utf8');
$query = mysqli_query($connect, "SELECT * FROM pages WHERE page_id = '".$page_id."'");
while($row = mysqli_fetch_assoc($query))
{
echo '<h3>'.$row['text'].'</h3>';
}
$query = mysqli_query($connect, "SELECT * FROM menu");
echo '<div id="menuArea">';
while($row = mysqli_fetch_assoc($query))
{
$menuName = $row['menuName'];
$menuElements = $row['menuElements'];
$menuElements = explode(", ", $menuElements);
echo '
<button id="'.$menuName.'"><h3 id="'.$menuName.'h3">'.$menuName.' ▾</h3></button>
<ul id="'.$menuName.'S" class="menuCollapseSecond">
';
foreach($menuElements as $menuElement)
{
echo '<li>'.$menuElement.'</li>';
}
echo '</ul>';
}
echo '</div>';
?>
</div>
<img id="sacImg" src="../images/sac.png">
<p>Copyright © Le Kerouac 2015</p>
</div>
<?php
$query = mysqli_query($connect, "SELECT * FROM menu");
while($row = mysqli_fetch_assoc($query))
{
echo '
<script type="text/javascript">
$(document).ready(function()
{
$("#'.$menuName.'").click(function()
{
$("'.$menuName.'S").slideToggle();
});
});
</script>
';
}
mysqli_close($connect);
?>
我将document.ready放到脚本中,并且也将脚本移到了页面底部,但这无济于事
javascript参考方案
首先,您需要在脚本部分中使用S将#添加到动态创建的ul id中,以便通过Id捕获DOM对象。
其次,使用jquery'on'函数,该函数可在创建该元素的任何时候将事件绑定到一个元素,因此您的代码应如下所示:
...
while($row = mysqli_fetch_assoc($query))
{
echo '
<script type="text/javascript">
$(document).ready(function()
{
$("#'.$menuName.'").on( "click", function() {
{
$("#'.$menuName.'S").slideToggle(); // adding # to catch element by Id
});
});
</script>
';
}
....
执行onclick时获得意外令牌 - javascript我正在使用onclick事件从PHP调用JS函数。这是我的代码:我在一个函数中,因此我需要通过PHP来完成它,因为然后我会返回:$html = '<input type="checkbox" checked value="1" id="setGetSku" name="se…
如何防止SQL使用单引号字符存储转义字符 - javascript我需要存储在开头和结尾都带有单引号的文本字符串。我正在从PHP发布JavaScript命令。我将引号添加到这样的字符串中:echo '<script type="text/javascript">'; echo 'function GetCodes() {'; echo 'va…
Mongo汇总 - javascript我的收藏中有以下文件{ "_id": ObjectId("54490b8104f7142f22ecc97f"), "title": "Sample1", "slug": "samplenews", "cat": …
JavaScript只在表格的第一行执行 - javascript我有一个重复的表行15次。然后在其中一个字段上执行JS。问题在于它仅在表的第一行执行JS。我究竟做错了什么?PHP Table脚本: for ($x = 1; $x <= 15; $x++) { echo '<tr>'; echo '<td><input size="6" …
Ajax功能后没有数据传递到URL - javascript这是我使用Ajax将参数传递到另一个PHP页面的脚本。 $(document).on( "click",".btndriver", function() { var id = $(this).attr("id"); var nombre = $(this).attr("nombre…