有没有办法使用jQuery和AJAX发布没有任何序列化的表单?

时间:2011-12-16 18:40:32

标签: php jquery ajax

我有一个包含动态创建的复选框的表单,用于过滤要显示的数据:

$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变量并将其设置为等于我的新数组名称。

3 个答案:

答案 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);
 });

从服务器端,您需要请求每个可变量