驚いたことに、この関数はまだ投稿されていませんが、他の関数には同様のバリエーションがあります。これは、Math.round()のMDN Webドキュメントからのものです。簡潔であり、さまざまな精度が可能です。
function precisionRound(number, precision) {
var factor = Math.pow(10, precision);
return Math.round(number * factor) / factor;
}
console.log(precisionRound(1234.5678、1)); //予想される出力:1234.6
console.log(precisionRound(1234.5678、-1)); //予想される出力: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'>
更新:Aug / 20/2019このエラーに気づきました。Math.round()の浮動小数点精度エラーが原因だと思います。
precisionRound(1.005, 2) // produces 1, incorrect, should be 1.01
これらの条件は正しく機能します。
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
修正:
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;
}
これは、小数を丸めるときに右側に数字を追加するだけです。MDNはMath.roundページを更新したので、誰かがより良い解決策を提供できるかもしれません。
0.1
有限の2進浮動小数点数にマップする方法がないためです。