将动态表单数据添加到ajax post请求

时间:2015-11-17 08:35:59

标签: javascript jquery html ajax

说我有一个带有以下内容的html表单

<form>
    <div id="si-main">
        <button id="si-btn">Add new content</button>
        <div class="si-content">
            <input type="text" class="si-input" name="content"> 
        </div>
    </div>

    <input type="submit" id="si-submit" value="Submit">
</form>

现在我想附加&#34; .si-content&#34;当我点击&#34;#si-btn&#34;我在JS中使用这个脚本

$('#si-btn').click(function() {
    $('#si-main').append('<div class="si-content"><input type="text" class="si-input" name="content"></div>')
})

然后我在JS中提交这样的表单

$('form #si-submit').click(function() {
    var data_to_send = {}
    $('form').find('.si-input').each(function() {
        if ($(this).hasClass('si-input')) {
            data_to_send[$(this).attr('name')] = $(this).val()      
        }
    })
    //NEXT I SEND THE AJAX REQUEST AND HANDLE THE RESPONSE
})

现在问题在于我添加了一个新的&#34; si-content&#34; DIV。但是当我发送数据时,它只发送第一个div的内容。有人能告诉我在这种情况下添加数据的最佳方法是什么?

1 个答案:

答案 0 :(得分:3)

尝试:

 $('#si-main').append('<div class="si-content"><input type="text" class="si-input" name="content[]"></div>');

$('form #si-submit').click(function() {
    var data_to_send =  $(this).parent('form').serialize();

    //NEXT SEND THE AJAX REQUEST AND HANDLE THE RESPONSE
})