javascript的parseFloat()方法精度问题

在Javascript中parseFloat()方法会产生精度问题

Js代码   收藏代码
  1. <script language="javascript">   
  2.   var a = "0.11";   
  3.   var b = "0.2801";   
  4.   var c = "1.002";   
  5.   var sum1 = parseFloat(a) + parseFloat(b) + parseFloat(c);   
  6.   var sum2 = (parseFloat(a) + parseFloat(b) + parseFloat(c)).toFixed(4)   
  7.   document.write("a+b+c=" + sum1);   
  8.   document.write("<br/>")   
  9.   document.write("a+b+c=" + sum2)   
  10. </script>   

 

a,b,c相加本来为1.3921,但sum1得出的结果为:1.3921000000000001,这不是想要的结果,特别在计算金钱的时候,不需要如此精确的精度。可以使用toFixed(n)方法修正后(n是小数后精确的位数)。

 例如:parseFloat(1.392143).toFixed(2)=1.39。

JavaScript中,`parseFloat`函数用于解析一个字符串并返回一个浮点数。不过,该函数存在精度问题。 `parseFloat`会尝试将字符串转换为浮点数,如果字符串开头是有效的数字字符,就会将其转换为对应的数字;若遇到非数字字符(除了开头的正负号、小数点),则停止解析并返回已解析的数字;若字符串开头就不是有效数字字符,则返回`NaN`。例如: ```javascript var num1 = parseFloat("123abc"); // 返回 123 var num2 = parseFloat("0xA"); // 返回 0 var num3 = parseFloat("11.2"); // 返回 11.2 var num4 = parseFloat("11.22.33"); // 返回 11.22 var num5 = parseFloat("0102"); // 返回 102 var num6 = parseFloat("red"); // 返回 NaN ``` 在进行小数计算时,`parseFloat`可能会出现精度失真的情况。比如: ```javascript var result = parseFloat("234432.9") - parseFloat("0.2"); console.log(result); // 输出 234432.69999999998 ``` 这是因为JavaScript内部使用IEEE 754双精度64位浮点数表示数字,在进行小数计算时会存在精度丢失的问题。 为解决`parseFloat`的精度问题,可采用以下方法: ```javascript function add(a, b) { var num1 = a.toString().split('.')[1]? a.toString().split('.')[1].length : 0; var num2 = b.toString().split('.')[1]? b.toString().split('.')[1].length : 0; var baseNum = Math.pow(10, Math.max(num1, num2)); return (a * baseNum + b * baseNum) / baseNum; } var result = add(234432.9, 0.2); console.log(result); // 输出 234433.1 ``` 此方法将小数转换为整数进行计算,之后再转换回小数,避免了直接使用浮点数计算导致的精度问题
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值