[英]Multiply and add 2 input boxes using jquery
我希望脚本将输入框的值乘以隐藏输入的值,然后在单击按钮时打印结果。
脚本几乎可以做到这一点,但只能用于1个输入。
有任何简单的方法吗?
非常感激。
小提琴: http : //jsfiddle.net/eN7S6/3/
<table>
<tr>
<td>
<input name="inputone" id="inputone" class="calc" value="1"><span id="Total"></span>
</td>
</tr>
<tr>
<td>
<input name="inputone" id="inputone" class="calc" value="1"><span id="Total"></span>
</td>
</tr>
</table>
<input name="inputtwo" id="inputtwo" class="calc" value="2" type="hidden" readonly>
<input name="inputtwo" id="inputtwo" class="calc" value="3" type="hidden" readonly>
<input type="button" id="update" value="Calculate" />
和jQuery
$(document).ready(function() {
$('#update').click(function() {
var inputone = $('#inputone').val();
var inputtwo = $('#inputtwo').val();
var totalTotal = ((inputone * 1) * (inputtwo * 1));
$('#Total').text(totalTotal);
});
});
您的元素ID不是唯一的。 您有重复项,例如“ inputone”和“ inputtwo”。
我已经更改了他们的名字,并增加了一个新的总跨度。
这是更新的代码:
<table>
<tr>
<td>
<input name="inputone" id="inputone" class="calc" value="1"><span id="TotalOne"></span>
</td>
</tr>
<tr>
<td>
<input name="inputtwo" id="inputtwo" class="calc" value="1"><span id="TotalTwo"></span>
</td>
</tr>
</table>
<input name="multiplierone" id="multiplierone" class="calc" value="2" type="hidden" readonly>
<input name="multipliertwo" id="multipliertwo" class="calc" value="3" type="hidden" readonly>
<input type="button" id="update" value="Calculate" />
和jQuery:
$(document).ready(function() {
$('#update').click(function() {
var inputone = $('#inputone').val();
var multiplierone = $('#multiplierone').val();
var inputtwo = $('#inputtwo').val();
var multipliertwo = $('#multipliertwo').val();
var totalTotalOne = (inputone * multiplierone);
var totalTotalTwo = (inputtwo * multipliertwo);
$('#TotalOne').text(totalTotalOne);
$('#TotalTwo').text(totalTotalTwo);
});
});
并更新了jsFiddle: http : //jsfiddle.net/eN7S6/4/
这个小算法将获取所有input.calc
元素并将它们的值相乘。 认为这应该基于给定的html为您工作。
var total = 1;
$("input.calc").val(function(idx, val) {
total*= val;
})
$('#Total').text(total);
永远不会有两个IDs
在同一个页面上是相同的,这就是发明class
的原因。
修改您的代码,如下所示:
<table>
<tr>
<td>
<input name="inputone"class="inputone calc" value="1"><span id="Total"></span>
</td>
</tr>
<tr>
<td>
<input name="inputone" class="inputone calc" value="1"><span id="Total"></span>
</td>
</tr>
</table>
<input name="inputtwo" class="calc inputtwo" value="2" type="hidden" readonly>
<input name="inputtwo" class="calc inputtwo" value="3" type="hidden" readonly>
<input type="button" id="update" value="Calculate" />
然后:
$(document).ready(function() {
$('#update').click(function() {
var inputone = $('.inputone').val();
var inputtwo = $('.inputtwo').val();
var totalTotal = ((inputone * 1) * (inputtwo * 1));
$('#Total').text(totalTotal);
});
});
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.