Chrome/Firefox 中頭toFixed方法四捨五入兼容性問題

每一個Number的toFixed()方法可把 Number 四捨五入爲指定小數位數的數字。四捨五入顧名思義,4及如下捨去,5及以上加1。javascript

 

四舍java

1.31.toFixed(1) // 1.3
1.32.toFixed(1) // 1.3
1.33.toFixed(1) // 1.3
1.34.toFixed(1) // 1.3

 

五入git

1.35.toFixed(1) // 1.4
1.36.toFixed(1) // 1.4
1.37.toFixed(1) // 1.4
1.38.toFixed(1) // 1.4
1.39.toFixed(1) // 1.4

 

IE6-10github

1.35.toFixed(1) // 1.4 正確
1.335.toFixed(2) // 1.34  正確
1.3335.toFixed(3) // 1.334 正確
1.33335.toFixed(4) // 1.3334 正確
1.333335.toFixed(5)  // 1.33334 正確
1.3333335.toFixed(6) // 1.333334 正確

 

但在 chrome44/firefox41 裏對於最後一位是 5 的有時居然沒有進位chrome

1.35.toFixed(1) // 1.4 正確
1.335.toFixed(2) // 1.33  錯誤
1.3335.toFixed(3) // 1.333 錯誤
1.33335.toFixed(4) // 1.3334 正確
1.333335.toFixed(5)  // 1.33333 錯誤
1.3333335.toFixed(6) // 1.333333 錯誤

能夠看到,小數點位數爲2,5時四捨五入是正確的,其它是錯誤的。es5

 

若是最後一位爲非 5 ,chrome44/firefox41 則沒有這個問題firefox

1.36.toFixed(1) // 1.4 正確
1.336.toFixed(2) // 1.34  正確
1.3336.toFixed(3) // 1.334 正確
1.33336.toFixed(4) // 1.3334 正確
1.333336.toFixed(5)  // 1.33334 正確
1.3333336.toFixed(6) // 1.333334 正確

 

修復方式blog

/*
 * 修復 firefox/chrome 中 toFixed 兼容性問題
 * firefox/chrome 中,對於小數最後一位爲 5 時進位不正確,修復方式即判斷最後一位爲 5 的,改爲 6, 再調用 toFixed
 */
function toFixed(number, precision) {
    var str = number + ''
    var len = str.length
    var last = str.substr(len-1, len)
    if (last == '5') {
        last = '6'
        str = str.substr(0, len-1) + last
        return (str - 0).toFixed(precision)        
    } else {
        return number.toFixed(precision)
    }
}

 

2015.10.26 補充:Firefox 和 Chrome的實現沒有問題,根本緣由是計算機裏浮點數精度丟失問題。修復方式改成ip

// toFixed 修復
function toFixed(num, s) {
	var times = Math.pow(10, s)
	var des = num * times + 0.5
	des = parseInt(des, 10) / times
	return des + ''
}

  

相關:ci

https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Number/toFixed

https://es5.github.io/#x15.7.4.5

相關文章
相關標籤/搜索