我有一个表单,在点击调用追加功能的按钮时动态添加输入。提交表单后,我只能访问在页面加载时创建的输入。我使用以下调试代码仔细检查了这一事实。警报确实不显示动态生成的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 非常感谢任何帮助
答案 0 :(得分:1)
1.我的一些结束语是用法语键盘制作的,因此错了。 我拿出了ID中的[]。