我有 4 个下拉菜单,即 dd1(parent)、dd2、dd3、dd4,最后三个下拉菜单的初始值为 null。
我使用 ajax 从父下拉列表中获取最后三个下拉列表。
我已经使用 php 验证(mkValid)来验证下拉菜单是否为空。
问题是当我在前 2 个下拉列表中选择一个值并且当我单击提交时,它得到验证但页面被刷新并且前两个下拉列表中的选定值变为空。所以,我需要保留这些值,直到所有下拉列表都有values.I 在 jquery 中使用了 ajax.stop() 但没有用。Help.!
我有 4 个下拉菜单,即 dd1(parent)、dd2、dd3、dd4,最后三个下拉菜单的初始值为 null。
我使用 ajax 从父下拉列表中获取最后三个下拉列表。
我已经使用 php 验证(mkValid)来验证下拉菜单是否为空。
问题是当我在前 2 个下拉列表中选择一个值并且当我单击提交时,它得到验证但页面被刷新并且前两个下拉列表中的选定值变为空。所以,我需要保留这些值,直到所有下拉列表都有values.I 在 jquery 中使用了 ajax.stop() 但没有用。Help.!
您必须验证下拉菜单客户端。PHP 是服务器端的,只有在将其发布到服务器后才进行验证。这发生在您单击“提交”后。
向我们展示您的代码;)
防止提交:
$('#form_id').submit(function(e) {
e.preventDefault();
// or
//return false;
})
你可以这样做:
<select name="dropdown">
<option value="1" <?php echo isset($_POST["dropdown"]) && $_POST["dropdown"] == "1" ? "selected"; ?> >Option 1</option>
<option value="2" <?php echo isset($_POST["dropdown"]) && $_POST["dropdown"] == "2" ? "selected"; ?> >Option 2</option>
<option value="3" <?php echo isset($_POST["dropdown"]) && $_POST["dropdown"] == "3" ? "selected"; ?> >Option 3</option>
</select>
您可以参考PHP 如何保持下拉列表中的选定选项以在提交时保持选中状态?了解更多信息
编辑:我刚刚读到您正在使用 Smarty,在这种情况下您可以使用:
<select name="dropdown">
<option value="1" {if !empty($dropdown) && $dropdown == "1"}selected{/if}>Option 1</option>
<option value="2" {if !empty($dropdown) && $dropdown == "2"}selected{/if}>Option 2</option>
<option value="3" {if !empty($dropdown) && $dropdown == "3"}selected{/if}>Option 3</option>
</select>
在你的 PHP 中:
global $smarty;
if(isset($_POST["dropdown"])){
//validation
$smarty->assign("dropdown", $_POST["dropdown"]);
}