Co zaskakujące, ta funkcja nie została jeszcze opublikowana, chociaż inni mają podobne odmiany. Pochodzi z dokumentów internetowych MDN dla Math.round (). Jest zwięzły i pozwala na różną precyzję.
function precisionRound(number, precision) {
var factor = Math.pow(10, precision);
return Math.round(number * factor) / factor;
}
console.log (precisionRound (1234.5678, 1)); // oczekiwany wynik: 1234,6
console.log (precisionRound (1234.5678, -1)); // oczekiwany wynik: 1230
var inp = document.querySelectorAll('input');
var btn = document.querySelector('button');
btn.onclick = function(){
inp[2].value = precisionRound( parseFloat(inp[0].value) * parseFloat(inp[1].value) , 5 );
};
//MDN function
function precisionRound(number, precision) {
var factor = Math.pow(10, precision);
return Math.round(number * factor) / factor;
}
button{
display: block;
}
<input type='text' value='0.1'>
<input type='text' value='0.2'>
<button>Get Product</button>
<input type='text'>
AKTUALIZACJA: 20 sierpnia 2019 Właśnie zauważyłem ten błąd. Uważam, że jest to spowodowane błędem precyzji zmiennoprzecinkowej w Math.round ().
precisionRound(1.005, 2) // produces 1, incorrect, should be 1.01
Te warunki działają poprawnie:
precisionRound(0.005, 2) // produces 0.01
precisionRound(1.0005, 3) // produces 1.001
precisionRound(1234.5, 0) // produces 1235
precisionRound(1234.5, -1) // produces 1230
Naprawić:
function precisionRoundMod(number, precision) {
var factor = Math.pow(10, precision);
var n = precision < 0 ? number : 0.01 / factor + number;
return Math.round( n * factor) / factor;
}
To dodaje cyfrę po prawej stronie podczas zaokrąglania miejsc po przecinku. MDN zaktualizował stronę Math.round, więc może ktoś mógłby zaoferować lepsze rozwiązanie.
0.1
na skończoną binarną liczbę zmiennoprzecinkową.