У меня есть функция javascript, которая автоматически добавляет поля ввода вместе, но добавление чисел, таких как 1.35 + 1.35 + 1.35, дает мне вывод 4.050000000000001, как пример. Как я могу округлить сумму до второго десятичного числа вместо этой длинной строки?
В полях ввода будет больше, чем просто пример 1.35, поэтому мне нужно, чтобы итоговое значение никогда не превышало 2 точек после запятой. Вот полный рабочий код:
<html>
<head>
<script type="text/javascript">
function Calc(className){
var elements = document.getElementsByClassName(className);
var total = 0;
for(var i = 0; i < elements.length; ++i){
total += parseFloat(elements[i].value);
}
document.form0.total.value = total;
}
function addone(field) {
field.value = Number(field.value) + 1;
Calc('add');
}
</script>
</head>
<body>
<form name="form0" id="form0">
1: <input type="text" name="box1" id="box1" class="add" value="0" onKeyUp="Calc('add')" onChange="updatesum()" onClick="this.focus();this.select();" />
<input type="button" value=" + " onclick="addone(box1);">
<br />
2: <input type="text" name="box2" id="box2" class="add" value="0" onKeyUp="Calc('add')" onClick="this.focus();this.select();" />
<input type="button" value=" + " onclick="addone(box2);">
<br />
<br />
Total: <input readonly style="border:0px; font-size:14; color:red;" id="total" name="total">
<br />
</form>
</body></html>
Некоторые вещи, которые я пробовал, должны работать, но я явно неправильно их реализую:
for(var i = 0; i < elements.length; ++i){
total += parseFloat(elements[i].value.toString().match(/^\d+(?:\.\d{0,2})?/));
var str = total.toFixed(2);
или
for(var i = 0; i < elements.length; ++i){
total += parseFloat(elements[i].value * 100) / 100).toFixed(2)
Также не повезло с Math.floor