更新:我使用第一个评论者的 checkNo[] 建议修改了代码,因为我认为它可能会有所帮助,而且无论如何它更优雅。
表单的初始硬编码字段组看起来几乎相同,除了我删除了“1”,例如“checkNo1”现在只是“checkNo”
用于创建新字段组的 jQuery 现在只需复制初始代码:
var checksDiv = $('#checkForms');
var i = $('#checkForms p').length + 1;
var checkForm = $('#checkForms').html(); //COPY THE FIELD GROUP CODE
$('#addCheck').click(function() {
$(checkForm).appendTo(checksDiv);
$('#checkCount').val(i);
i++;
});
现在循环看起来像这样:
for (i=1;i <= Request.Form("checkNo").Count; i++){ // LOOP THROUGH CHECKS
thisCheck = Request.Form("checkNo")(i);
thisAmt = Request.Form("amt")(i);
thisInvoices = Request.Form("invoices")(i);
}
结果?它仍然出现未定义......好像jQuery生成的字段不存在......但它们存在。我看到它们,我填写它们,我在 html 中看到它们......它们在那里,但是当我发布表格时,它们就像消失了一样。
vvvvvvvvvvv 更新前 vvvvvvvvvvvvvvv
我的表单中有一部分(用户可以在其中添加检查)如下所示:
<div id="checkForms">
<p>
<label for="checkNo1">
<input type="text" id="checkNo1" size="20" name="checkNo1" value="" placeholder="Check Number" />
</label>
<label for="amt1">
| $<input type="text" id="amt1" size="20" name="amt1" value="" placeholder="Amount" />
</label>
<br/>
<label for="invoices1">
<textarea name="invoices1" id="invoices1" placeholder="Invoice Amt" cols="50" rows="10"></textarea>
</label>
</p>
<hr/>
</div>
<h3><a href="javascript:void(0)" id="addCheck">Add Another Check</a></h3>
<input type="hidden" id="checkCount" name="checkCount" value="1">
<input type="submit" name="submit" value="send" class="button sendit">
我有 jQuery 添加这样的新字段:
var checksDiv = $('#checkForms');
var i = $('#checkForms p').size() + 1;
$('#addCheck').click(function() {
$('<p><label for="checkNo' + i +'"><input type="text" id="checkNo' + i +'" size="20" name="checkNo' + i +'" placeholder="Check Number" /></label> | $<label for="amt' + i +'"><input type="text" id="amt' + i +'" size="20" name="amt'+ i +'" placeholder="Amount" /></label><br/><label for="invoices' + i +'"><textarea name="note" placeholder="Invoice Amt" cols="50" rows="10"></textarea></label><a href="javascript:void(0)" class="remCheck">Remove</a></p><hr/> ').appendTo(checksDiv);
$('#checkCount').val(i);
i++;
});
这很好用,他们出现了....
然后在提交后,我正在访问这样的值:
for (i=1;i <= checkCount; i++){
thisCheck = Request.Form("checkNo"+i);
thisAmt = Request.Form("amt"+i);
etc....
第一组“硬编码”字段工作正常,但动态创建的所有内容都“未定义”。我也试过这样:
for (i=1;i <= checkCount; i++){
thisCheck = "checkNo"+i;
thisCheck = Request.Form(thisCheck);
etc....
并验证它正在请求正确的表单字段名称。