我有几行输入框(文本)需要迭代,将一行中的值相乘,然后对乘积求和。我能找到的唯一解决方案是将输入框转换为数组:
var array1 = $('input[id$="txtVal1"]').toArray();
var array2 = $('input[id$="txtVal2"]').toArray();
var temp1;
var temp2;
var sum=0;然后使用以下命令进行迭代和求和:
for (i = 0; i < array1.length; i++) {
if (array1[i].value.length > 0) { //make sure we have data
temp1 = parseFloat(array1[i].value);
temp2 = parseFloat(array2[i].value);
sum += temp1 * temp2;
}
}这是可行的。然而,我只是在学习JQuery,并且想使用规范方法。
发布于 2013-03-27 23:35:57
您可以直接循环遍历通过选择器找到的所有项,如下所示:
$('input').each(function(index,data) {
var value = $(this).val();
});发布于 2013-03-27 23:53:44
如前所述,您可以使用.each()来完成此任务,但这里有一个示例,它根据问题中的请求使用您的数据。你提到了输入的“行”,所以我假设它在一个表行中:
$('tr').each(function () {
var $this = $(this),
sum = parseFloat($this.find('input[id$="txtVal1"]').val()) * parseFloat($this.find('input[id$="txtVal2"]').val());
alert(sum);
});这是一个jsFiddle Example
发布于 2013-03-27 23:35:02
不需要使用toArray,使用.each()方法。
$('input[id$="txtVal1"]').each(function(index) {
// do something here
$(this).addClass( "myClass" );
})https://stackoverflow.com/questions/15662836
复制相似问题