例如,我需要将6.688689舍入到6.7,但它总是显示7。

我的方法:

Math.round(6.688689);
//or
Math.round(6.688689, 1);
//or 
Math.round(6.688689, 2);

但结果总是一样的7…我做错了什么?


当前回答

如果你现在正在使用Browserify,你将不得不尝试:roundTo一个非常有用的NPM库

其他回答

使用toFixed()函数。

(6.688689).toFixed(); // equal to "7"
(6.688689).toFixed(1); // equal to "6.7"
(6.688689).toFixed(2); // equal to "6.69"
Number((6.688689).toFixed(1)); // 6.7

我有很好的解决方案,如果toFixed()不工作。

function roundOff(value, decimals) {
  return Number(Math.round(value+'e'+decimals)+'e-'+decimals);
}

例子

roundOff(10.456,2) //output 10.46

我认为这个函数会有帮助。

 function round(value, ndec){
    var n = 10;
    for(var i = 1; i < ndec; i++){
        n *=10;
    }

    if(!ndec || ndec <= 0)
        return Math.round(value);
    else
        return Math.round(value * n) / n;
}


round(2.245, 2) //2.25
round(2.245, 0) //2

还有另一个. tolocalestring()来格式化数字,有很多关于地区、分组、货币格式和符号的选项。一些例子:


四舍五入到小数点后1,返回一个浮点数:

Const n = +6.688689。toLocaleString (fullwide, {maximumFractionDigits: 1}) console.log ( N类型的N )


四舍五入至2位小数,格式为带有指定符号的货币,千位使用逗号分组:

console.log ( 68766.688689.toLocaleString('fullwide', {maximumFractionDigits:2, style:'currency', currency:'USD', useGrouping:true}) )


格式为区域货币:

console.log ( 68766.688689.toLocaleString('fr-FR', {maximumFractionDigits:2, style:'currency', currency:'EUR'}) )


四舍五入到最小3位小数,强制0显示:

游戏机。log ( 6.000000.toLocaleString(’fullwide’,(minimumFractionDigits: 3)) )


百分比风格的比率。输入* 100,带%符号

游戏机。log ( 6.688689.toLocaleString(' fullwed ') )