如何使用jQuery使用JSON和AJAX Post Method在数组中发送类似的数据

时间:2016-09-30 08:22:36

标签: javascript jquery ajax

HTML CODE

<form id="details">
  <div>
    <input type="text" placeholder="Email ID" id="email"></input>
    <input type="text" placeholder="Mobile Number" id="mobile"></input>
</div>
<h5>Data</h5>
<div>
    <div>
        <input type="text" placeholder="Name" id="name1"></input>
        <input type="text" placeholder="Age" id="age1"></input>
    </div>
    <div>
        <input type="text" placeholder="Name" id="name2"></input>
        <input type="text" placeholder="Age" id="age2"></input>
    </div>
</div>
</form>

JS CODE

$(document).ready(function() {
    $("form").on('submit', function(e) {
        // Prepare data
        var form = $("form");
        var formData = new FormData(document.getElementById("details"));
        e.preventDefault();
        $.ajax(form.attr('action'), {
            type: 'POST',
            data: formData,
            contentType: false,
            cache: false,
            processData:false,
            dataType: "json",
            success: function(result) {
                // Success Code
            },
            error: function(result) {
                // Failure Code
            },
            timeout: 5000,
        });
    });
});

我的代码的codepen链接是http://codepen.io/anon/pen/VKzGRG

我想发送像

这样的数据
{
    "email" : "xyz@gmail.com",
    "mobile" : "9898989898",
    "data" : [
        {
            "name":"xyz",
            "age":45
        },
        {
            "name":"xyz",
            "age":45
        }
    ]
}

我尝试使用jQuery发送数据。

问题在于它只发送一个名字和年龄。

此外,在我的项目中,我使用jQuery和一个按钮动态添加名称和年龄框。

如何使用jQuery使用AJAX post方法发送数据?

2 个答案:

答案 0 :(得分:1)

您错过了输入的名称,这就是数据未发布的原因 见下面的工作代码。

// HTML代码

<form  name="details" action="t.php" id="details">
  <div>
    <input type="text" name="email" placeholder="Email ID" id="email"></input>
    <input type="text" name="mobile" placeholder="Mobile Number" id="mobile"></input>
</div>
<h5>Data</h5>
<div>
    <div>
        <input type="text" name="data1[]" placeholder="Name" id="name1"></input>
        <input type="text" name="data1[]" placeholder="Age" id="age1"></input>
    </div>
    <div>
        <input type="text" name="data2[]" placeholder="Name" id="name2"></input>
        <input type="text" name="data2[]" placeholder="Age" id="age2"></input>
    </div>
</div>
<input type="submit" value="send">
</form>

// ajax代码

$(document).ready(function() {
    $("form").on('submit', function(e) {
        // Prepare data
        var form = $("form");
        var formData = new FormData(document.getElementById("details"));
        console.log(formData);
        e.preventDefault();
        $.ajax(form.attr('action'), {
            type: 'POST',
            data: formData,
            contentType: false,
            cache: false,
            processData:false,
            dataType: "json",
            success: function(result) {
                // Success Code
            },
            error: function(result) {
                // Failure Code
            },
            timeout: 5000,
        });
    });
});

答案 1 :(得分:0)

要使用jQuery和Ajax发布数据,您可以执行类似这样的操作

var myObj = {
    "email" : "xyz@gmail.com",
    "mobile" : "9898989898",
    "data" : [
        {
            "name":"xyz",
            "age":45
        },
        {
            "name":"xyz",
            "age":45
        }
    ]
};

$.post( "test.php", myObj)
.done(function( data ) {
    alert( "Data Loaded: " + data );
  });

这将发布数据并提醒请求的响应。