最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 『前端BUG』—— toFixed四舍五入的不准确性|牛气冲天新年征文

    正文概述 掘金(红尘炼心)   2021-02-10   766

    前言

    某天,客服告诉我,有客户投诉,说账单金额数据统计不对,同时测试也反馈在IE11浏览器上又是正确的。

    经过排查发现是toFixed()引起的。

    缘由

    来看一下toFixed()在chrome、火狐、IE下的不同表现。

    chrome:

    『前端BUG』—— toFixed四舍五入的不准确性|牛气冲天新年征文

    火狐:

    『前端BUG』—— toFixed四舍五入的不准确性|牛气冲天新年征文

    IE:

    『前端BUG』—— toFixed四舍五入的不准确性|牛气冲天新年征文

    可以看到toFixed()的四舍五入在chrome、火狐上并不准确。

    toFixed()在chrome、火狐上也并不是网上所说的用银行家舍入法来进行四舍五入的。

    例如银行家舍入法在 (2.55).toFixed(1) = 2.5(3.55).toFixed(1) = 3.5 上就不符合了。

    那为什么会这样呢,要从toFixed的定义说起,来看ecmascript 规范对toFixed的表述:

    『前端BUG』—— toFixed四舍五入的不准确性|牛气冲天新年征文

    按上图中的步骤来演示一下(2.55).toFixed(1) = 2.5的处理过程。

    x为2.55,小于102110^{21}1021,f为1,要使n÷10fxn\div10^f-xn÷10f−x准确的数学值尽可能接近零,取n为25和n为26,

    『前端BUG』—— toFixed四舍五入的不准确性|牛气冲天新年征文

    可以看到最接近零的应该是 -0.04999... ,故n为25,那么m为25,k为2,kfk-fk−f为1,故a为2,则b为5,所以(2.55).toFixed(1)的结果为2.5

    可以看出(2.55).toFixed(1)的结果是2.5而不是2.6,是25/102.55=0.049999925/10-2.55=-0.049999925/10−2.55=−0.0499999... 引起,而25/102.5525/10-2.5525/10−2.55为什么不等于0.50.50.5,其原因和0.1+0.20.1+0.20.1+0.2不等0.30.30.3是一样,可以看我这篇专栏。

    但是在IE浏览器中,执行 25/102.5525/10-2.5525/10−2.55 和 26/102.5526/10-2.5526/10−2.55 的结果和在chrome和火狐浏览器中执行的结果是一样。这里只能推断IE浏览器中定义的toFixed不符合ecmascript 规范,具体原因目前也不清楚,如果知道的同学可以在评论中留言,谢谢。

    解决

    假设要四舍五入的数字为number,要保留n位小数,可以先用number10nnumber*10^nnumber∗10n ,然后用 Math.round()取整,最后在除去10n10^n10n,间接实现四舍五入。另外toFixed()还有个自动补零的功能,也要实现一下,故下面简单封装了一个toFixed方法来实现四舍五入。

    function toFixed(number, m) {
        if (typeof number !== 'number') {
            throw new Error("number不是数字");
        }
        let result = Math.round(Math.pow(10, m) * number) / Math.pow(10, m);
        result = String(result);
        if (result.indexOf(".") == -1) {
            result += ".";
            result += new Array(m + 1).join('0');
        } else {
            let arr = result.split('.');
            if (arr[1].length < m) {
                arr[1] = arr[1] += new Array(m - arr[1].length + 1).join('0')
            }
            result = arr.join('.')
        }
        return result
    }
    

    起源地下载网 » 『前端BUG』—— toFixed四舍五入的不准确性|牛气冲天新年征文

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元