JS中toFixed()方法的问题及解决方案

最近发现JS当中toFixed()方法存在一些问题,采用原生的Number对象的原型对象上的toFixed()方法时,规则并不是所谓的“四舍五入”或者是“四舍六入五成双”,所谓“四舍六入五成双”,在百度百科上给的解释是:也即“4舍6入5凑偶”这里“四”是指≤4 时舍去,"六"是指≥6时进上,"五"指的是根据5后面的数字来定,当5后有数时,舍5入1;当5后无有效数字时,需要分两种情况来讲:①5前为奇数,舍5入1;②5前为偶数,舍5不进。(0是最小的偶数) 。百度百科上涉及的几个例子在实际情况下确实成立,但不科学,并不能覆盖所有的情况。

测试浏览器:屌丝浏览器IE6以及高级屌丝浏览器IE78(此处为方便未使用原生IE678,不过IETester破天荒地表现良好,精确做法应该是一个版本对应一个虚拟机来测试)和所有现代主流浏览器包括IE9、IE10、FF、Chrome、Opera、Safari。(注:在使用IE10的类似firebug的开发工具时,采用兼容IE低版本浏览器模式时的测试结果跟使用原生低版本IE浏览器的测试结果不一致)

在浮点数末尾≤4或者≥6的情况下的舍入没有争议,但当末尾正好等于5的情况下可谓混乱之极。

一、FF 稳定版测试结果如下所示:

二、FF Aurora测试结果如下所示:

三、FF Nightly的测试结果如下所示:

四、Chrome稳定版的测试结果如下所示:

五、Chromium的测试结果如下所示:

六、Chrome Canary的测试结果如下所示:

七、Opera稳定版的测试结果如下所示:

八、Opera Next的测试结果如下所示:

九、Safari的测试结果如下所示:

十、IE6-8的测试结果如下所示:

十一、IE9、10的测试结果如下所示:

总结:众所周知,遵循IEEE754数值格式的语言的浮点计算会出现精度损耗的通病,ES也并非独此一家,因此尽量不要进行某个特定浮点数值的测试,如:0.1+0.2;

解决方案:重写Number.prototype.toFixed()方法:

<html><head><script type="text/javascript">Number.prototype.toFixed=function (d) { var s=this+""; if(!d)d=0; if(s.indexOf(".")==-1)s+="."; s+=new Array(d+1).join("0"); if(new RegExp("^(-|\\+)?(\\d+(\\.\\d{0,"+(d+1)+"})?)\\d*$").test(s)){var s="0"+RegExp.$2,pm=RegExp.$1,a=RegExp.$3.length,b=true;if(a==d+2){a=s.match(/\d/g); if(parseInt(a[a.length-1])>4){for(var i=a.length-2;i>=0;i--){a[i]=parseInt(a[i])+1;if(a[i]==10){a[i]=0;b=i!=1;}else break;}}s=a.join("").replace(new RegExp("(\\d+)(\\d{"+d+"})\\d$"),"$1.$2");}if(b)s=s.substr(1); return (pm+s).replace(/\.$/,"");}return this+"";};</script></head><body><input type="button" value="显示0.009.toFixed(2)" οnclick="alert(0.009.toFixed(2))"><br /><input type="button" value="显示0.123.toFixed(2)" οnclick="alert(0.123.toFixed(2))"><br /><input type="button" value="显示0.125.toFixed(2)" οnclick="alert(0.125.toFixed(2))"><br /><input type="button" value="显示0.126.toFixed(2)" οnclick="alert(0.126.toFixed(2))"><br /><input type="button" value="显示20.445.toFixed(2)" οnclick="alert(20.445.toFixed(2))"><br /><input οnclick="alert(20.405.toFixed(2))" type="button" value="显示20.405.toFixed(2)"> <br /><input οnclick="alert(20.415.toFixed(2))" type="button" value="显示20.415.toFixed(2)"> <br /><input οnclick="alert(20.425.toFixed(2))" type="button" value="显示20.425.toFixed(2)"> <br /><input οnclick="alert(20.435.toFixed(2))" type="button" value="显示20.435.toFixed(2)"> <br /><input οnclick="alert(20.445.toFixed(2))" type="button" value="显示20.445.toFixed(2)"> <br /><input οnclick="alert(20.455.toFixed(2))" type="button" value="显示20.455.toFixed(2)"> <br /><input οnclick="alert(20.465.toFixed(2))" type="button" value="显示20.465.toFixed(2)"> <br /><input οnclick="alert(20.475.toFixed(2))" type="button" value="显示20.475.toFixed(2)"> <br /><input οnclick="alert(20.485.toFixed(2))" type="button" value="显示20.485.toFixed(2)"> <br /><input οnclick="alert(20.495.toFixed(2))" type="button" value="显示20.495.toFixed(2)"> <br /><input οnclick="alert(0.05.toFixed(1))" type="button" value="显示0.05.toFixed(1)"> <br /><input οnclick="alert(0.15.toFixed(1))" type="button" value="显示0.15.toFixed(1)"> <br /><input οnclick="alert(0.25.toFixed(1))" type="button" value="显示0.25.toFixed(1)"> <br /><input οnclick="alert(0.35.toFixed(1))" type="button" value="显示0.35.toFixed(1)"> <br /><input οnclick="alert(0.45.toFixed(1))" type="button" value="显示0.45.toFixed(1)"> <br /><input οnclick="alert(0.55.toFixed(1))" type="button" value="显示0.55.toFixed(1)"> <br /><input οnclick="alert(0.65.toFixed(1))" type="button" value="显示0.65.toFixed(1)"> <br /><input οnclick="alert(0.75.toFixed(1))" type="button" value="显示0.75.toFixed(1)"> <br /><input οnclick="alert(0.85.toFixed(1))" type="button" value="显示0.85.toFixed(1)"> <br /><input οnclick="alert(0.95.toFixed(1))" type="button" value="显示0.95.toFixed(1)"> <br /></body>
</html>

 文章转载:http://www.cnblogs.com/gushen/archive/2012/11/20/2778324.html#undefined

转载于:https://www.cnblogs.com/wangsaiming/p/4644790.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/492064.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

AI的阿基里斯之踵:模糊性

来源&#xff1a;IEEE电气电子工程师学会摘要&#xff1a;网罗全球科技前沿动态&#xff0c;为科研创业打开脑洞。很多年前&#xff0c;我和一位朋友去参观一个果园。他的儿子是这个果园的经理&#xff0c;向我们介绍了其工作。我的这位朋友和我都是工程师&#xff0c;开始讨论…

哈勃望远镜进一步确认宇宙在加速膨胀

来源&#xff1a;新华社美国哈勃太空望远镜的新观测成果进一步确认了宇宙在加速膨胀&#xff0c;现在的膨胀速度比根据早期宇宙特征预测的膨胀速度快大约9%。此次研究成果25日发表在美国《天体物理学杂志》上。研究人员利用新方法对大麦哲伦星云的70颗造父变星进行了观测。有“…

Git的安装和配置

Git的安装和配置 一、下载并安装git git下载地址 所有均选择默认值&#xff0c;一路NEXT 二、下载并安装tortoisegit 所有均选择默认值&#xff0c;一路NEXT 三、新建GitHub存储库 1.打开github官方网站&#xff0c;注册账号 2.登录后点击绿色NEW按钮 3.进入如图所示&am…

AI芯片重磅破局者,开启边缘新智元

来源&#xff1a;物联网智库摘要&#xff1a;曾几何时&#xff0c;我们惊讶于AI算力和智力的创新程度&#xff0c;但彼时AI所创造的产业价值并不明显。随着移动互联网时代走向物联网时代&#xff0c;越来越多的场景和终端需要对数据进行即时高效的处理&#xff08;如车联网、无…

Python学习笔记(序列和元组)

序列和元组 序列是指一种包含多项数据的数据结构&#xff0c;序列包含的多个数据项(成员)按顺序排列&#xff0c;可通过索引&#xff08;下标&#xff09;&#xff0c;来访问序列成员。Python常见的序列包括字符串、元组、列表等&#xff0c;字节串也是序列&#xff0c;namedt…

Python学习笔记(列表和元组的简单实用)

一、通过索引访问元素 1.列表和元组都可通过索引来访问元素 一种是正向访问&#xff0c;从左到右&#xff0c;索引从0开始&#xff0c;第一个元素的索引为0&#xff0c;第二个为1&#xff0c;以此类推。 另一种是反向访问&#xff0c;从右到左&#xff0c;索引从-1开始&#…

《全球人工智能发展报告(2018)》发布:一览全球AI领域竞争态势

来源&#xff1a;乌镇智库乌镇智库《全球人工智能发展报告》以宏观视角纵览全球人工智能的发展&#xff0c;覆盖了知识产权、投融资、人才、应用场景等多个维度&#xff0c;为读者清晰地展现出人工智能全球发展的最新趋势&#xff0c;各国在人工智能领域的竞争态势以及中国各地…

解读|智能技术“核聚变”催生智能经济,将拉动十万亿市场

来源&#xff1a;阿里研究院从IT时代、互联网到智能 2019年政府工作报告&#xff0c;正式提出了“智能”战略&#xff1a;“深化大数据、人工智能等研发应用。打造工业互联网平台&#xff0c;拓展‘智能’&#xff0c;为制造业转型升级赋能。”以5G、物联网、人工智能等技术为代…

C#课堂笔记(二)

C#基础 一、C#中的命名空间 C#程序中的一种代码组织形式&#xff0c;主要用来标识类的可见范围&#xff0c;使用namespace关键字定义命名空间。 在C#中&#xff0c;使用命名空间用using关键字。 二、类的概念 1.什么是类&#xff1f; 类是一种数据结构&#xff0c;存储数…

【转】使用Auto Layout中的VFL(Visual format language)--代码实现自动布局

原文&#xff1a;http://www.cocoachina.com/ios/20141209/10549.html 本文将通过简单的UI来说明如何用VFL来实现自动布局。在自动布局的时候避免不了使用代码来加以优化以及根据内容来实现不同的UI。 一&#xff1a;API介绍 NSLayoutConstraint API 1 NSLayoutConstraint cons…

5G时代来临,高通如何让AI触手可及?

来源&#xff1a;量子位在高通人工智能开放日之后&#xff0c;我们需要再次刷新对高通这家公司的认知了。不需要耗费巨大的算力&#xff0c;高通与vivo、腾讯王者荣耀、腾讯AI Lab合作&#xff0c;他们正共同打造一支AI电竞战队“SUPEX”&#xff0c;将与人类玩家对战。让手机芯…

C#课堂笔记(三)

C#变量类型 一、数据类型 1.值类型 简单&#xff1a;整数、实数、字符、布尔 复合&#xff1a;结构、枚举 值类型直接存储值&#xff0c;在栈中分配存储空间。简单类型&#xff1a;数值型&#xff0c;字符型&#xff0c;布尔型 &#xff08;1&#xff09;整数类型 &#…

国产统一操作系统(UOS)安装、体验

一、UOS简介 &#xff08;1&#xff09;UOS介绍 统一操作系统是由统信软件开发的一款基于Linux内核的操作系统&#xff0c;分为统一桌面操作系统和统一服务器操作系统。统一桌面操作系统以桌面应用场景为主&#xff0c;统一服务器操作系统以服务器支撑服务场景为主&#xff0…

2019上海车展展后报告(整车篇)

来源&#xff1a;智车科技未来智能实验室是人工智能学家与科学院相关机构联合成立的人工智能&#xff0c;互联网和脑科学交叉研究机构。未来智能实验室的主要工作包括&#xff1a;建立AI智能系统智商评测体系&#xff0c;开展世界人工智能智商评测&#xff1b;开展互联网&#…

C++中的STL--基本概念

STL基本概念 一.什么是STL&#xff1f; STL(Standard Template Library),是C标准模板库&#xff0c;是C标准库的重要组成部分&#xff0c;不仅是一个可复用的组件库&#xff0c;而且是一个包罗数据结构与算法的软件框架 二.STL的版本 1. 原始版本&#xff1a;由Alexander S…

华为帝国全景

来源&#xff1a;智东西摘要&#xff1a;营收超BAT之和&#xff01;从芯到云&#xff0c;一文看懂华为帝国4大业务板块。2018年与2019年注定是中国智能手机行业发展史上浓墨重彩一年。全面屏、AI芯片、多摄、3D结构光、潜望摄像头等一大波新技术浪潮全面席卷了整个智能手机产业…

Dynamics CRM 依赖组件类型为应用程序功能区导致的无法删除实体问题的解决方法...

看到有人问到这个问题&#xff0c;这边就简单描述下解决方法&#xff0c;主要是针对第一次碰到这个问题云里雾里的朋友&#xff0c;错误如下 在我们建lookup关联的时候有下图中的这么个设置&#xff0c;对于很多新手默认就是下图这样不会去做改动&#xff0c;因为本身也没人告诉…