我正在尝试做一些事情,当你在表单的输入框中输入细节,用Ajax加载信息,然后在下面添加另一行。到目前为止我所做的是填充第一个输入框,使用ajax获取数据,并添加一行新的输入框。但是,当我在第二行时,它不能正常运行。 我的代码是:
<form role="form" class="container" method="POST" id="form" action="">
<div class="row" data-line="1">
<div class="col-md-2">
<div class="form-group">
<label for="ticketNo">Ref #</label>
<input type="text" name="ticketNo" class="form-control" id="ticketNo" ind="1" placeholder="Ref #">
</div>
</div>
<div class="col-md-2">
<div class="form-group">
<label for="amount">Price</label>
<input type="text" name="amount" class="form-control" id="amount" placeholder="" disabled>
</div>
</div>
<div class="col-md-2">
<div class="form-group">
<label for="agent">Agent</label>
<input type="text" name="agent" class="form-control" id="agent" placeholder="" disabled>
</div>
</div>
<div class="col-md-2">
<div class="form-group">
<label for="received">Amount Received</label>
<input type="text" name="received" class="form-control" id="received" placeholder="">
</div>
</div>
</div>
</form>
<script type="text/javascript">
$(document).ready(function () {
var rowCntr = 1;
$("#ticketNo").blur(function () {
$.ajax({
url: "payment_ss.php?action=getInfo&p="+$(this).val(),
success: function (result) {
var ar = result.split("|");
console.log(rowCntr);
$(".row[data-line='"+ rowCntr +"'] #amount").val(ar[0]);
$(".row[data-line='"+ rowCntr +"'] #received").val(ar[0]);
$(".row[data-line='"+ rowCntr +"'] #agent").val(ar[1]);
}
});
});
$("#received").bind('keyup', function(e) {
if (e.which == 13) {
var app = $('<div class="row"><div class="col-md-2"><div class="form-group"><input type="text" name="ticketNo" class="form-control" id="ticketNo" ind="1" placeholder="Ref #"></div></div><div class="col-md-2"><div class="form-group"><input type="text" name="amount" class="form-control" id="amount" placeholder="" disabled></div></div><div class="col-md-2"><div class="form-group"><input type="text" name="agent" class="form-control" id="agent" placeholder="" disabled></div></div><div class="col-md-2"><div class="form-group"><input type="text" name="received" class="form-control" id="received" placeholder=""></div></div></div>');
$("#form").append(app);
app.attr("data-line", rowCntr);
$("[data-line='"+ rowCntr +"'] #ticketNo").focus();
rowCntr++;
}
});
});
</script>
答案 0 :(得分:1)
尝试
$("#received").on( 'keyup' , function(e) {
if (e.which == 13) {
var app = $('<div class="row"><div class="col-md-2"><div class="form-group"><input type="text" name="ticketNo" class="form-control" id="ticketNo" ind="1" placeholder="Ref #"></div></div><div class="col-md-2"><div class="form-group"><input type="text" name="amount" class="form-control" id="amount" placeholder="" disabled></div></div><div class="col-md-2"><div class="form-group"><input type="text" name="agent" class="form-control" id="agent" placeholder="" disabled></div></div><div class="col-md-2"><div class="form-group"><input type="text" name="received" class="form-control" id="received" placeholder=""></div></div></div>');
$("#form").append(app);
app.attr("data-line", rowCntr);
$("[data-line='"+ rowCntr +"'] #ticketNo").focus();
rowCntr++;
}
});