POST表单动态生成输入

时间:2014-12-28 03:33:25

标签: javascript php jquery forms submit

我有一个表单,在点击调用追加功能的按钮时动态添加输入。提交表单后,我只能访问在页面加载时创建的输入。我使用以下调试代码仔细检查了这一事实。警报确实不显示动态生成的ID。

$('form').submit(function() {
    alert($(this).serialize());
    return false;
  });

脚本如下:

$(document).ready(function() {
    var max_fields      = 10; //maximum input boxes allowed
    var wrapper         = $(".input_fields_wrap"); //Fields wrapper
    var add_button      = $(".add_field_button"); //Add button ID

    var x = 0; //initlal text box count
    $(add_button).click(function(e){ //on add input button click
        e.preventDefault();
        if(x < max_fields){ //max input box allowed
            x++;
            var printCounter = document.getElementById("product_counter");
            printCounter.value = x; 
            //increment
            $(wrapper).append('<div>' +
        '<div class="input-group">' +
        '<span class="input-group-addon">Nom</span>'+
                    '<input id="vch_invoice_item['+x+']” name="vch_invoice_item['+x+']” value="" type="text" class="form-control" placeholder="">'+
                 '</div>'+
                '<div class="input-group">'+
                   '<span class="input-group-addon">Description</span>'+
                  '<input id="vch_invoice_description['+x+']” name="vch_invoice_description['+x+']" value="" type="text" class="form-control" placeholder="">'+
                '</div>'+
            '<div class="input-group">'+
                   '<span class="input-group-addon">Prix à l’unité</span>'+
                  '<input onclick="bindPriceMask(this)" onfocus="bindPriceMask(this)" id="vch_invoice_unitcost['+x+']” name="vch_invoice_unitcost['+x+']” value="" type="text" class="unit form-control" placeholder="">'+
                '</div>'+
            '<div class="input-group">'+
                   '<span class="input-group-addon">Quantité</span>'+
                  '<input onclick="bindQtyMask(this)" onfocus="bindQtyMask(this)" id="vch_invoice_quantity['+x+']” name="vch_invoice_quantity['+x+']” value="" type="text" class="qty form-control" placeholder="">'+
                '</div>'+
            '<div class="input-group">'+
                   '<span class="input-group-addon">Taxe Fédérale</span>'+
                  '<input onclick="bindTaxMask(this)" onfocus="bindTaxMask(this)" id="vch_invoice_fedTax['+x+']” name="vch_invoice_fedTax['+x+']” value="" type="text" class="taxf form-control" placeholder="">'+
                '</div>'+
            '<div class="input-group">'+
                   '<span class="input-group-addon">Taxe Provinciale</span>'+
                  '<input onclick="bindTaxMask(this)" onfocus="bindTaxMask(this)" id="vch_invoice_provTax['+x+']” name="vch_invoice_provTax['+x+']” value="" type="text" class="taxp form-control" placeholder="">'+
                '</div>'+
        '<a href="#" class="remove_field">Supprimer</a><br><br><br>'+
                '</div>'); //add input box
        }
    });

    $(wrapper).on("click",".remove_field", function(e){ //user click on remove text
        e.preventDefault(); $(this).parent('div').remove(); x--;
    })
});

jsfiddle.net/52VtD/9763 非常感谢任何帮助

1 个答案:

答案 0 :(得分:1)

1.我的一些结束语是用法语键盘制作的,因此错了。 我拿出了ID中的[]。