Jquery:在每行中计算,每行显示相同的结果

时间:2016-09-12 04:18:55

标签: javascript jquery frontend

我有一个具有动态功能的表来添加行。这意味着用户可以添加任意数量的结果。

行有一个选择字段和一个文本输入字段。当用户从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值计算金额。 enter image description here

JSfiddle没有ajax部分:

https://jsfiddle.net/tL86dsmc/

&#13;
&#13;
$("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;
&#13;
&#13;

3 个答案:

答案 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). 
无论选择哪个更改控件,

都将访问每个输入元素。