1. 程式人生 > >JS toFixed 四捨六入五成雙

JS toFixed 四捨六入五成雙

以前一直以為toFixed就是四捨五入的方法,後來又有一段時間以為toFixed是五舍六入。今天終於寫的時候,終於才知道toFixed是一個叫做四捨六入無成雙的詭異的方法。。。

完全不明白為什麼要這麼寫。。。

什麼是四捨六入五成雙:百度是這麼說的:

對於位數很多的近似數,當有效位數確定後,其後面多餘的數字應該捨去,只保留有效數字最末一位,這種修約(舍入)規則是“四捨六入五成雙”,也即“4舍6入5湊偶”這裡“四”是指≤4 時捨去,"六"是指≥6時進上,"五"指的是根據5後面的數字來定,當5後有數時,舍5入1;當5後無有效數字時,需要分兩種情況來講:①5前為奇數,舍5入1;②5前為偶數,舍5不進。(0是偶數)

所以也就是說: (0.557).toFixed(2) => 0.56   然而 (0.567).toFixed(2)=>0.56,這並不是我們想用的四捨五入的方法。所以可以這麼修改:

基礎方法:

//乘法函式  
function accMul(arg1, arg2) {  
    var m = 0, s1 = arg1.toString(), s2 = arg2.toString();  
    try {  
        m += s1.split(".")[1].length;  
    }  
    catch (e) {  
    }  
    try {  
        m += s2.split(".")[1].length;  
    }  
    catch (e) {  
    }  
    return Number(s1.replace(".", "")) * Number(s2.replace(".", "")) / Math.pow(10, m);  
}   

//給Number型別增加一個mul方法,使用時直接用 .mul 即可完成計算。   
Number.prototype.mul = function (arg) {  
    return accMul(arg, this);  
};   

//除法函式  
function accDiv(arg1, arg2) {  
    var t1 = 0, t2 = 0, r1, r2;  
    try {  
        t1 = arg1.toString().split(".")[1].length;  
    }  
    catch (e) {  
    }  
    try {  
        t2 = arg2.toString().split(".")[1].length;  
    }  
    catch (e) {  
    }  
    with (Math) {  
        r1 = Number(arg1.toString().replace(".", ""));  
        r2 = Number(arg2.toString().replace(".", ""));  
        return (r1 / r2) * pow(10, t2 - t1);  
    }  
}   
//給Number型別增加一個div方法,,使用時直接用 .div 即可完成計算。   
Number.prototype.div = function (arg) {  
    return accDiv(this, arg);  
};


toFixed方法:

// 修改toFixed方法,由原本的四捨六入五成雙,改為四捨五入
Number.prototype.toFixed = function(s) { 
    changenum=(parseInt(this.mul(Math.pow( 10, s ) + 0.5)).div(Math.pow( 10, s ))).toString(); 
    index=changenum.indexOf("."); 

    if(index<0&&s>0){ 
        changenum=changenum+"."; 
        for(i=0;i<s;i++){ 
            changenum=changenum+"0"; 
        } 
    }else { 
        index=changenum.length-index; 
        for(i=0;i<(s-index)+1;i++){ 
            changenum=changenum+"0"; 
        } 
    } 
    return changenum; 
}