[转]Js中parseFloat()方法所产生的精度问题

Demo:

<script language="javascript">
var a = "0.11";
var b = "0.2801";
var c = "1.002";
var sum1 = parseFloat(a)+parseFloat(b)+parseFloat(c);
var sum2 = (parseFloat(a)+parseFloat(b)+parseFloat(c)).toFixed(4)
document.write("a+b+c="+sum1);
document.write("<br/>")
document.write("a+b+c="+sum2)
</script>

a,b,c相加本来为1.3921,但sum1得出的结果为:1.3921000000000001,显然不正确,通过toFixed(n)方法修正后(n是精确的小数点位数),得到正确结果。

如:parseFloat(1.392143).toFixed(3)=1.392;

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 ``` 此方法将小数换为整数进行计算,之后再换回小数,避免了直接使用浮点数计算导致的精度问题
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值