【问题标题】:Simulate html form POST using ajax/jquery使用 ajax/jquery 模拟 html 表单 POST
【发布时间】:2013-09-04 11:15:28
【问题描述】:

我想从表单中读取所有发布变量及其内容并使用 jquery 的“$.post()”发布它们。 首先,这不会完成工作: $.post("myServer.com/test2.php", $('#myform').serialize()) 因为它只会发送一个我必须在 php 端解析的变量。

我会这样开始:

function doIndirectPost() {
    variableWithTheFormPOSTData = {};
    $("#IdOfMyForm :input").each(function() {
        variableWithTheFormPOSTData[$(this).attr("name")] = $(this).attr("value");
    }
    document.getElementById("IdOfMyForm").submit();
    $.post("myServer.com/test2.php", variableWithTheFormPOSTData);
}

然后我想使用 $.post() 来发布分隔在多个变量中的数据(就像普通的表单提交一样...... 我在某处读到,您可以这样做:

$.post('myserver.com/test2.php.php',{
    var1: content1,
    var2: content2
}

但我希望它是动态的。这部分:

    var1: content1,
    var2: content2

应该自动包含表单的所有变量名和值。

最后我希望能够像这样获得所有 POST 变量:

foreach ($_POST as $key => $value)
{
    echo $key . "= " . $value;
}

【问题讨论】:

  • 你试过serializeArray()吗?
  • "首先,这不起作用:$.post("myServer.com/test2.php", $('#myform').serialize()) 因为它会只发送一个变量”——这根本不是真的。它将使用标准表单编码方法发送表单中所有成功的输入,PHP 会自动对其进行解码并填充$_POST
  • 真的吗?有人告诉我必须使用 parse_str($_POST['serialize'], $data);在上面。身份证
  • 只有当你做了一些愚蠢的事情,比如:$.post('foo.php', { serialize: $('#myform').serialize() });

标签: php javascript jquery html ajax


【解决方案1】:

序列化不只发送一个变量,它发送表单中所有输入元素的名称值对。所以

    $("#IdOfMyForm").on("submit", function () {
        $.post("myServer.com/test2.php", $("#IdOfMyForm").serialize(), 
                function(dataFromServer){
                   //server sent a response now do whatever you want to do after form has been submitted 
                   //or submit form regular way $("#IdOfMyForm").submit();
                 }
        );
        return false;
    });

应该可以。请记住在表单中设置每个输入/选择元素的名称属性。

【讨论】:

  • 不错且简单的答案。也许你甚至可以说:$.post($("#IdOfMyForm").attr('action'),$("#IdOfMyForm").serialize(),
【解决方案2】:

您是否尝试过使用 JQuery 的 Ajax 代替?

喜欢这个答案: jQuery Ajax POST example with PHP

【讨论】:

    猜你喜欢
    • 2016-01-30
    • 2019-08-03
    • 2021-12-07
    • 2011-06-16
    • 2013-04-25
    • 2021-01-17
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多