前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >JS数字精度丢失的问题

JS数字精度丢失的问题

原创
作者头像
愤怒的小鸟
修改2020-12-30 15:39:47
6.7K0
修改2020-12-30 15:39:47
举报
文章被收录于专栏:web shareweb share

一、一些典型问题

1. 两个简单的浮点数相加

0.1 + 0.2 != 0.3 // true

2. 大整数运算

9999999999999999 == 10000000000000001 // true

9007199254740992 + 1 == 9007199254740992 // true

3. toFixed不会四舍五入(Chrome)

1.335.toFixed(2) // 1.33

二、解决方案

1. toFixed() 因为toFixed() 进行并转换之后是string类型的,需要在进行强制Number() 转换

代码语言:javascript
复制
Number((0.1+0.2).toFixed(2))

2. 一些类库

math.js

3. 转为整数

  • 对于整数,前端出现问题的几率可能比较低,毕竟很少有业务需要需要用到超大整数,只要运算结果不超过 Math.pow(2, 53) 就不会丢失精度。
  • 对于小数,前端出现问题的几率还是很多的,尤其在一些电商网站涉及到金额等数据。解决方式:把小数放到位整数(乘倍数),再缩小回原来倍数(除倍数)。

// 0.1 + 0.2

(0.1*10 + 0.2*10) / 10 == 0.3 // true

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
作者已关闭评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、一些典型问题
  • 二、解决方案
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档