接口返回超16位number数据 JS显示丢失精度解决方法

联调接口时发现后端返回的不同对象的id重复,浏览器开发者工具查看预览如下图:

 通过postman测试接口,返回数据与后端确认一致

 百度后发现,后端返回的id字段number类型数据太长了,有19位,超过了js中number类型的最大值2的53次方即9007199254740992,若超过了这个值会出现精度丢失问题。

而且,由于本项目后端返回的是JSON格式的数据,axios响应会自动转换成js对象,浏览器预览看到的结果即为丢失精度后的数据。

出现这种情况,可以与后端沟通,让后端将id的number类型数据处理成string类型后返回给前端;

或者,引入第三方包 json-bigint,使用.parse()方法将超过安全值的number值转换成BigNumber:

安装:npm i json-bigint

导入:import bigInt from "json-bigint"

例:

const jsonStr = '{"num":7083720390568443904}'

console.log(bigInt.parse(jsonStr)) // 转换为BigNumber

console.log(bigInt.parse(jsonStr).num.toString()) // 对目标属性调用.toString()方法可得到正确的字符串

由于axios的特性,我们需要在响应数据被转换成js对象之前,将目标属性的值改为BigNumber;

可以在axios请求时,添加transformResponse配置选项,使响应数据在传递给then/catch 前进行一些修改

axios({

        method: "post",

        url: "xxx",

        params: { xxx },

        transformResponse: [

          function (data) {

            return bigInt.parse(data); // 把响应数据中的"大数"的值转换为一个js字符串对象

          },

        ],

        headers: { "Content-Type": "application/x-www-form-urlencoded" },

      })

      .then((res)=>{

        // 找到目标属性,调用.toString()方法将BigNumber转换为字符串

      })

参考链接:

解决js中大数的问题

axios中文文档|axios中文网 | axios (axios-js.com)

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
JavaScript中,数字类型被表示为64精度浮点数,也就是IEEE754标准的浮点数。由于这种表示方式的限制,JavaScript中的数字类型在处理某些特定的数时可能会丢失精度。 其中一个常见的情况是处理小数。由于浮点数总是以二进制形式存储,而不是十进制形式,所以在某些十进制小数的转换和计算过程中,可能会导致精度丢失。例如,0.1在二进制表示中是一个无限循环的数字,因此在进行计算时可能会产生舍入误差,导致结果不准确。 另一个常见的情况是处理大整数。由于JavaScript中的数字类型有限的存储长度(64),过这个长度的整数可能会被截断,导致精度丢失。这在涉及到大数运算、精确计算或需要非常精确结果的场景中可能会带来问题。 为了解决这些问题,可以使用一些技巧来确保精度不受影响。比如,可以使用一些库或工具来处理大数运算,避免使用浮点数进行货币计算等需要精确结果的情况。此外,可以使用一些特定的算法或技术,如使用字符串表示数而不是直接使用数字类型,避免使用浮点数进行累计计算,使用专门处理小数的库等。 总的来说,尽管JavaScript中的数字类型在处理一些特定数时可能丢失精度,但可以采取一些措施来减小这种影响,以确保需要精确计算的场景中的结果是准确的。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值