JS toFixed 四舍六入五成雙


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

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

 

什么是四舍六入五成雙:百度是這么說的:

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

 

所以也就是說: (0.5251).toFixed(2) => 0.53   然而 (0.525).toFixed(2)=>0.52,這並不是我們想用的四舍五入的方法。所以可以這么修改:

基礎方法:

//乘法函數
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) {//關於js中with關鍵字的使用請查看鏈接 http://luopq.com/2016/02/14/js-with-keyword/
         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;  
}      
轉自:http://www.68idc.cn/help/buildlang/ask/20150411317631.html

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM