实现toFixed()的最可靠方法是什么?

时间:2013-09-25 20:21:57

标签: javascript

我正在尝试以可靠的方式实现toFixed()以舍入到小数位(当前的toFixed()函数在不同的浏览器中返回不同的结果)。

我的想法是用Number.prototype.toFixed = function(c){};

实现它

我尝试了很多选项,但只有一个选项似乎工作正常,但我对此并不自信:

乘以/除以10几次并舍入((0.069).toFixed(2);返回“0.06999999999999999”):

Number.prototype.toFixed = function(c){
    var c =  isNaN(c = Math.abs(c)) ? 0 : c;
    var n = this;
    for(var i=0; i<c; i++){
        n *= 10;
    }
    n = Math.round(n);
    for(var i=0; i<c; i++){
        n /= 10;
    }
    n = (n+"").split(".");
    if(c==0){
        return n[0];
    }
    if(n[1] == void 0){
        n[1] = "";
    }
    while(n[1].length<c){
        n[1]+="0";
    }
    return n[0]+"."+n[1];
};

通过将数字作为字符串进行管理(我仍然有这个错误,例如:(0.0999).toFixed(2)给我“1.10”)

Number.prototype.toFixed = function(c){
    var c =  isNaN(c = Math.abs(c)) ? 0 : c;
        var d = (this+"").split(".");
        if(d[1] == void 0){
            d[1] = "";
        }
        if(d[1].length>c){
            if(parseInt(d[1].charAt(c))>=5){
                var cont = 0;
                while(cont<c-1&&d[1].charAt(cont)==='0'){
                    cont++;
                }
                var temp="";
                while(cont--){
                    temp += "0";
                }
                d[1]=temp+(parseInt(d[1].substring(0,c))+1)+"";
                if(d[1].length>c){
                    d[0]=(parseInt(d[0])+1)+"";
                    d[1]=d[1].substring(1);
                }
            } else {
                d[1] = d[1].substring(0,c);
            }
        }
        if(c==0){
            return d[0];
        }
        while(d[1].length<c){
            d[1]+="0";
        }
        return d[0]+"."+d[1];
};

乘以/除以10 ^ c并四舍五入我没有看到任何问题,但我不太自信:

Number.prototype.toFixed = function(c){
    var c =  isNaN(c = Math.abs(c)) ? 0 : c;
    var n = this;
    var z = "1";
    for(var i=0; i<c; i++){
        z+="0";
    }
    n = Math.round(n*z);
    n /= z;
    n = (n+"").split(".");
    if(c==0){
        return n[0];
    }
    if(n[1] == void 0){
        n[1] = "";
    }
    while(n[1].length<c){
        n[1]+="0";
    }
    return n[0]+"."+n[1];
};

我最好的选择是字符串操作,因为你不会弄乱浮点数的不确定性,尽管它比我想象的更难调试,我开始相信我永远不会完美。除了这些之外,还有其他人已经实施了吗?

1 个答案:

答案 0 :(得分:1)

以下是我使用的代码:

function RoundNumber(input, numberDecimals)
{
  numberDecimals = +numberDecimals || 0; // +var magic!

  var multiplyer = Math.pow(10.0, numberDecimals);

  return Math.round(input * multiplyer) / multiplyer;
}

示例:

console.log( RoundNumber(1234.6789, 0) ); // prints 1234
console.log( RoundNumber(1234.6789, 1) ); // prints 1234.6
console.log( RoundNumber(1234.6789, 2) ); // prints 1234.67
console.log( RoundNumber(1234.6789, -1) ); // prints 1230

我在Chrome和Firefox中使用过它。