我有一个包含动态创建的复选框的表单,用于过滤要显示的数据:
$html .= "<form id='optionsForm'action='filter.php' method='post'>";
foreach($selectValues as $key => $value){
$title=new MODEL\String($key);
$html.= "<fieldset class='optionsBox'>";
$html.= "<legend>".$title->friendlify()."</legend><br/>";
foreach($value as $option){
$html .= "<input type='checkbox' name='".$key."[]' value='$option'>".htmlspecialchars($option)."</input>";
}
$html.= "</fieldset>";
}
$html .= "</select><input type='submit' value='submit'></form></div>";
这会构建包含复选框值的多个数组,例如
name =>
[0] value1
[1] value2
newname =>
[0] value1
[1] value2
提交后,数组将传递给php函数,该函数将它们分开,然后使用数据运行查询。
我的问题是,当我使用jQuery .ajax
函数时,它会序列化数据,而我无法按照我想要的方式使用它。
使用我必须处理表单的相同表单操作的简单方法是什么,但结果显示在复选框下面的div
?
我想更好的问题是,当表单操作中使用的filter.php获取信息时,来自ajax的变量名称是什么? 现在我只使用_POST变量并将其设置为等于我的新数组名称。
答案 0 :(得分:1)
$('#optionsForm').submit(function() {
$.ajax({
url: this.action,
type: "POST"
data: $(this).serialize(),
// ...
// add success/complete/error handlers
});
return false;
});
.serialize()
将格式化数据,就像使用提交按钮提交的标准表单一样。
单击您的提交按钮将执行此ajax并阻止默认的表单操作。
答案 1 :(得分:1)
如果您不喜欢jQuery序列化数据的方式,您可以在POST到服务器之前根据表单值准备自己的有效负载。您应该可以根据需要格式化数据。
答案 2 :(得分:0)
你可以简单地使用
$.post("test.php?data1=1&data2=2", function(data) {
alert("Data Loaded: " + data);
});
从服务器端,您需要请求每个可变量