1

現在このように送信されているデータを変換するために何をしなければならないのか疑問に思っていました (を使用serializeArray())

data[0][name]:title
data[0][value]:This is my sample title
data[1][name]:description
data[1][value]:This is an (optional) description but I'm filling it out as an example
data[2][name]:source
data[2][value]:http://www.cnn.com
data[3][name]:category
data[3][value]:animals

代わりにこのように送信するには:

data[title]:This is my sample title
data[description:This is an (optional) description but I'm filling it out as an example
data[source]:http://www.cnn.com
data[category]:animals

コード:

$(function() {
    $('input[type="submit"]').click(function() {
        var $data = $('#js-serialize').serializeArray();
        console.log($data);
        $.post('/echo/json', {
            'data': $data
        }, function(data) {
            console.log(data);
        }, 'json');
        return false;

    });

});

<form id="js-serialize">
<input name="title" placeholder="title" />
<input name="description" placeholder="description" />
<input name="source" placeholder="source" />
<input name="category" placeholder="category"/>
<input type="submit" name="submit" />
</form>​

デモ:

http://jsfiddle.net/someprimetime/bnPwN/5/

4

2 に答える 2

0

配列ではなくオブジェクト表現を探しているようです。

jQuery は、すぐに使えるようなものをサポートしていませんserializeObject()ただし、このプラグインは、まさにあなたが望むことをしているようです。

于 2012-08-21T19:39:28.307 に答える