Вопрос:

ParseFloat округления

javascript math parsefloat

64447 просмотра

5 ответа

463 Репутация автора

У меня есть функция 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

Автор: JB. Источник Размещён: 09.01.2011 04:56

Ответы (5)


62 плюса

95978 Репутация автора

Решение

Используйте toFixed()для округления numдо 2 десятичных цифр, используя традиционный метод округления. Округление с 4.050000000000001 до 4.05.

num.toFixed(2);

Вы можете предпочесть использование toPrecision(), которое лишит любые конечные нули.

Пример :

1.35+1.35+1.35 => 4.050000000000001
(1.35+1.35+1.35).toFixed(2)     => 4.05
(1.35+1.35+1.35).toPrecision(3) => 4.05

// or...
(1.35+1.35+1.35).toFixed(4)     => 4.0500
(1.35+1.35+1.35).toPrecision(4) => 4.05

Ссылка: JavaScript Number Format - десятичная точность

Автор: marcog Размещён: 09.01.2011 05:00

3 плюса

0 Репутация автора

var num = 4.050000000000001;

num = num.toFixed(2);

toFixed будет округляться в зависимости от того, сколько цифр после запятой вы ищете.

Автор: user1385191 Размещён: 09.01.2011 05:00

0 плюса

305922 Репутация автора

Вместо округления вы можете использовать порт Java BigDecimal для получения точной десятичной математики.

Автор: Michael Borgwardt Размещён: 09.01.2011 05:15

1 плюс

11 Репутация автора

Это работает:

$(document).ready(
    function() {
            $('#field1').blur(function(){ $('#field2').val(parseFloat($(this).val() * 2.2).toFixed(1)); });
            $('#field2').blur(function(){ $('#field1').val(parseFloat($(this).val() / 2.2).toFixed(1)); });
    }
);

Это не удается:

$(document).ready(
    function() {
            $('#field1').blur(function(){ $('#field2').val(parseFloat($(this).val() * 2.2)).toFixed(1); });
            $('#field2').blur(function(){ $('#field1').val(parseFloat($(this).val() / 2.2)).toFixed(1); });
    }
);

Так что будьте осторожны при размещении скобок () ... В первом случае округление будет работать, а во втором - не будет ...

Автор: Real Melancon Размещён: 01.06.2012 06:59

2 плюса

0 Репутация автора

Вы можете использовать Math.round(total*100000000000)/100000000000;в коде. Это будет работать для большинства случаев

Автор: user1938455 Размещён: 20.01.2016 07:42
Вопросы из категории :
32x32