题
这是一个相关的问题,一个我先前张贴...我想总结与道达尔在“totalpull”输入字段“拉”和地方开始所有输入元素。我有一部分工作。现在,我想,如果用户输入在“totalpull”输入字段中手动东西来计算平均每个“拉”的输入设置为该值。下面尝试,但它不工作...
//This is the sum formula, which works
$('input[name^=pull]').bind('keyup', function() {
$('#totalpull').val( $('input[name^=pull]').sumValues() );
});
$.fn.sumValues = function() {
var sum = 0;
$("input[name^='pull']").each(function() {
if ( $(this).is(':input') ) {
var val = $(this).val();
} else {
var val = $(this).text();
}
sum += parseFloat( ('0' + val).replace(/[^0-9-\.]/g, ''), 10 );
});
return sum;
};
//This is the avg formula, which does not work
//Keep getting v / rowCount.replace is not a function
$('input[name=totalpull]').bind('keyup', function() {
$('input[name^=pull]').each(function() {
$(this).val( $('input[name=totalpull').avgValues() );
});
});
$.fn.avgValues = function() {
var avg = 0;
var v = $("input[name=totalpull").val();
var rowCount = $("#convertRow tr").length;
avg += parseFloat( (v / rowCount).replace(/[^0-9-\.]/g, ''), 10);
return avg;
}
<table id="convert">
<tbody>
<tr><td><input type="text" value="" name="pull0" /></td></tr>
<tr><td><input type="text" value="" name="pull1" /></td></tr>
<tr><td><input type="text" value="" name="pull2" /></td></tr>
<tr><td><input type="text" value="" name="pull3" /></td></tr>
</tbody>
<tfoot>
<input type="text" id="totalpull" name="totalpull" value="" />
</tfoot>
</table>
解决方案
您当前的问题只是一个语法错误:
avg += parseFloat( (v / rowCount).replace(/[^0-9-\.]/g, ''), 10);
有是在若干没有replace
。你需要在抛出toString
:
avg += parseFloat( (v / rowCount).toString().replace(/[^0-9-\.]/g, ''), 10 );
顺便说一句,这里还有一个字符串没有/
(如v是),但JavaScript就尝试将其转换为你,给你NaN
,如果它不能。
其他提示
在您的sumValues功能,你重复“输入[名^ =拉]”选择器。您应该选择传递到你的函数,或者你已经得到的值行事。
在sumValues,“这个”应的输入的集合。因此,你应该能够做这样的事情:
$.fn.sumValues = function() {
var sum = 0;
this.each(function() {
sum += $(this).val();
});
return sum;
}
你还要“输入”和“:输入”混淆。 “输入”是输入标记。 :输入是任何输入或选择标记
。当总和被手动改变,该值被分配给“拉*”字段:
$('input[name=totalpull]').bind('keyup', function() {
var inp = $('input[name^=pull]');
inp.val(parseFloat($(this).val()) / inp.length);
});
不隶属于 StackOverflow