POST 表单动态生成的输入

POST form dynamically generated inputs

本文关键字:输入 表单 动态 POST      更新时间:2023-09-26

>我有一个表单,单击调用追加函数的按钮时,输入会动态添加到其中。提交表单后,我只能访问在页面加载时创建的输入。我已经使用以下调试代码仔细检查了这一事实。警报确实不显示动态生成的 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.我的一些结束语是用法语键盘做的,因此是错误的。2.我取出了ID中的[ ]。