怎么解决javascript小数相减会出现一长串的小数位数?

本文探讨了JavaScript中数值相减导致精度丢失的问题,并提供了一个优化解决方案,通过字符串转换和toFixed方法,确保计算结果的精确性。文章还介绍了自定义的String.prototype.toFloat方法,进一步提升了数值处理的灵活性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

例如parseFloat(11.3-10.1) 或者直接11.3-10.1    出来的结果是1.200000000000001

最终只能取个相对理想的方法,但是还是没有达到预期希望的那样把

就是在你相减完之后,进行小数点的取舍

parseFloat(11.3-10.1).toFixed(1)

例外js里面的字符串转换为数字的话,可以直接通过*1来实现

例如:parseFloat(“1.27”*1 - “1.11”*1).toFixed(2)

 

论坛里一个牛人给出的总结方法:

String.prototype.toFloat=Number.prototype.toFloat=function(decimalPlace,isRoundUp){

/// <summary>
/// String,Number原型扩展:保留指定的小数位数[可选择是否使用四舍五入]
/// </summary>
/// <param name="decimalPlace">需要保留的小数位</param>
/// <param name="isRoundUp">是否是舍五入[可选项:默认true]</param>
/// <returns>数据类型:Number(浮点数)</returns>

decimalPlace = decimalPlace || 0,
isRoundUp = Object.prototype.toString.call(isRoundUp).match(/^\[object\s(.*)\]$/)[1].toLowerCase()=='boolean' ? isRoundUp : !0;
try{
var res = isRoundUp
? (this*1).toFixed(decimalPlace)
: this.toString().replace(new RegExp("([0-9]+\.[0-9]{"+decimalPlace+"})[0-9]*","g"),"$1");
return isNaN(res*1) ? this: res;
}catch(e){
return isNaN(this*1) ? this : this*1;//防止小数位数字越界
}
}
alert(parseFloat(11.3-10.1222222).toFloat(2,!0))

转载于:https://www.cnblogs.com/wenghaowen/p/3185998.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值