我正在使用这个颜色框代码:
<link rel="stylesheet" href="http://www.jacklmoore.com/colorbox/example1/colorbox.css">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js"></script>
<script src="http://www.jacklmoore.com/colorbox/jquery.colorbox.js"></script>
<script>
$(document).ready(function(){
$("#cboxFormButton").click(function(e){
e.preventDefault();
$.colorbox({
href: $(this).closest('form').attr ('action'),
data: {a: $("input#111").val()}
});
return false;
});
});
</script>
以及这两个相同的POST操作按钮:
<form action="rrr1.php" method="POST" target="_blank" class="">
<input id="111" name="a" type="hidden" value="1"/>
<input type="submit" id="cboxFormButton" class="button" value="Test">
</form>
</div>
<div>
<form action="rrr1.php" method="POST" target="_blank" class="">
<input id="111" name="a" type="hidden" value="1"/>
<input type="submit" id="cboxFormButton" class="button" value="Test">
</form>
这是加载的目标rrr1.PHP文件:
<?php
if(isset($_POST['a']));
switch ($_POST['a']) {
case "1":
$param1 = "1";
break;
case "2":
$param1 = "2";
break;
default:
$param1 = "other";
}
当我点击第一个按钮时,会打开一个模态窗口并加载PHP就好了, 但是当我点击第二个按钮时,它只是直接重定向到PHP文件。
这是因为他们共享相同的ID吗?
让我们说我想拥有100个相同的按钮,并且每个按钮只需改变输入的值(现在是“1”,它将是2,3,4 ... 100)。 我希望模态窗口以相同的方式保持工作,并根据这些变化的值显示不同的内容。所以基本上我宁愿不为每个按钮添加额外的代码。
导致问题的原因是什么?什么是最有效的解决方案?
修改
现在我可以理解我必须像这样繁殖代码:
<script>
$(document).ready(function(){
$("#cboxFormButton1").click(function(e){
e.preventDefault();
$.colorbox({
href: $(this).closest('form').attr ('action'),
data: {a: $("input#111").val()}
});
return false;
});
});
$(document).ready(function(){
$("#cboxFormButton2").click(function(e){
e.preventDefault();
$.colorbox({
href: $(this).closest('form').attr ('action'),
data: {a: $("input#222").val()}
});
return false;
});
});
</script>
<form action="rrr1.php" method="POST" target="_blank" class="">
<input id="111" name="a" type="hidden" value="1"/>
<input id="qqq" name="b" type="hidden" value="1"/>
<input type="submit" id="cboxFormButton1" class="button" value="Test">
</form>
<form action="rrr1.php" method="POST" target="_blank" class="">
<input id="222" name="a" type="hidden" value="2"/>
<input type="submit" id="cboxFormButton2" class="button" value="Test">
</form>
有更高效/更短的代码吗?
答案 0 :(得分:2)
对于HTML元素,ID必须是唯一的。使用元素名称和相对位置来获取数据。然后你可以完全删除冲突的ID。
<form action="rrr1.php" method="POST" target="_blank" class="">
<input name="a" type="hidden" value="1"/>
<input type="submit" class="button cboxFormButton" value="Test">
</form>
<form action="rrr1.php" method="POST" target="_blank" class="">
<input name="a" type="hidden" value="2"/>
<input type="submit" class="button cboxFormButton" value="Test">
</form>
<script type="text/javascript">
$(document).ready(function(){
$(".cboxFormButton").click(function(e){
e.preventDefault();
var $form = $(this).closest('form');
$.colorbox({
href: $form.attr('action'),
data: {a: $form.find('input[name="a"]').val()}
});
return false;
});
});
</script>
答案 1 :(得分:0)