我在html中的代码获取用户输入数字并进行计算,然后显示输出。用户选择的输入被放入公式中,公式的结果被添加到用户输入数字,但是当它将两个数字相加时,它会添加一个小数点。例如,如果选择数字11,则Rchange的结果为0.22,因此.22为newResistance添加11为11.22,而是将值显示为110.22。
function calc(form) {
if (isNaN(form.resistance.value)) {
alert("Error in input");
return false;
}
if (form.resistance.value.length > 32) {
alert("Error in input");
return false;
}
var Rchange = .01 * 2 * form.resistance.value;
var newResistance = (form.resistance.value + Rchange);
document.getElementById("newResistance").innerHTML = chopTo4(newResistance);
}
function chopTo4(raw) {
strRaw = raw.toString();
if (strRaw.length - strRaw.indexOf("0") > 4) strRaw = strRaw.substring(0, strRaw.indexOf("0") + 5);
return strRaw;
}
答案 0 :(得分:0)
试试newResistance = +form.resistance.value + Rchange;
。这会将其转换为数字。
答案 1 :(得分:0)
HTML DOM元素属性始终是字符串。您需要将它们转换为使用中的数字。
parseInt(form.resistance.value);
parseFloat(form.resistance.value);
+form.resistance.value;
(这三个中的任何一个都可以工作;我更喜欢前两个(除非你正在寻找浮点数,否则使用parseInt))
答案 2 :(得分:0)
因为它将值视为字符串。
form.resistance.value + Rchange都是字符串,所以它附加它。
使用parseInt javascript方法获取十进制版本