我有一个具有动态功能的表来添加行。这意味着用户可以添加任意数量的结果。
行有一个选择字段和一个文本输入字段。当用户从select字段中选择一个值时,文本输入字段将填充Ajax调用给出的结果与表单上的另一个输入字段相乘。
我得到了结果,但问题是每行中的每个文本输入都填充了相同的结果。
这是我的代码: HTML
<table>
<tr class="items2"><td><select id="Account" value="1">ajax text</td><td><input class "amount"/></td></tr>
<tr class="items2"><td><select id="Account-1" value="2">ajax text</td><td><input class "amount"/></td></tr>
</table>
Jquery的:
<script>
$("select[id*='Account']").change(function(){
subjectId=$(this).val();
console.log(subjectId);
var sale=$("#id_sale").val();
console.log(sale);
request_url = '{% url "taxrate" pk=0 %}'.replace('0', subjectId);
console.log( "request_url = " + request_url);
$.ajax({
url: request_url,
type: "GET",
dataType: 'json',
}).done(function(data, textStatus, jqXHR) {
$.each(data, function(n, obj){
$("tr.items2").each(function () {
$('.amount',this).val( ((sale*obj.fields.rate)/100).toFixed(2));
})
})
})
});
</script>
我的代码中有什么错误?我只是前端的新手。
图像:在图像中,您可以看到文本输入在两个框中都显示为140。但是只有当我选择另一行选择项时它才会显示金额。应根据为行传递的ajax值计算金额。
JSfiddle没有ajax部分:
https://jsfiddle.net/tL86dsmc/
$("select[id*='Account']").change(function(){
subjectId=$(this).val();
var sale=$("#id_sale").val();
var tax_rate = ((sale * .10)).toFixed(2);
$(".amount").val(tax_rate);
});
&#13;
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<input type="text" id="id_sale" value=100>
<table>
<tr class="items2">
<td>
<select id="Account-1" value="1">
<option value="" selected="selected">---------</option>
<option value="1">tax @18%</option>
<option value="2">Tax @ 17%</option>
</select>
</td>
<td>
<input id="amount-2" class="amount">
</td>
</tr>
<tr class="items2">
<td>
<select id="Account-2" value="1">
<option value="" selected="selected">---------</option>
<option value="1">tax @18%</option>
<option value="2">Tax @ 17%</option>
</select>
</td>
<td>
<input id="amount-2" class="amount">
</td>
</tr>
</table>
&#13;
答案 0 :(得分:0)
使用课程
尝试<script>
$(".items2").change(function(){
subjectId=$(this).val();
console.log(subjectId);
var sale=$("#id_sale").val();
console.log(sale);
request_url = '{% url "taxrate" pk=0 %}'.replace('0', subjectId);
console.log( "request_url = " + request_url);
$.ajax({
url: request_url,
type: "GET",
dataType: 'json',
}).done(function(data, textStatus, jqXHR) {
$("tr.items2").each(function () {
$(this).find('.amount').val(((sale*obj.fields.rate)/100).toFixed(2));
})
})
});
</script>
答案 1 :(得分:0)
由于attribute-contains-selector因为Moment.js Timezone而得到相同的结果,因此每次用户添加行时,脚本都会选择值为1的id,并将其值插入到输入文本字段中。您可以尝试使用类更改脚本中的id选择。
答案 2 :(得分:0)
应该是,
$(this).parent().next().find('input.amount')
.val(((sale * data[0].fields.rate) / 100).toFixed(2));
删除此部分
$.each(data, function(n, obj) {
$("tr.items2").each(function() {
$('.amount', this).val(((sale * obj.fields.rate) / 100).toFixed(2));
})
})
问题
$('.amount',this).
无论选择哪个更改控件,都将访问每个输入元素。