js对于大数值获取显示和计算处理

JS处理大数值时会因最大安全数限制而失去精度。在Vue前端开发中,后台返回数字获取时也会有此问题。可使用插件将“大数”转换为字符串对象解决,还可借助bignumber插件进行计算,处理数据时参数需提前转成字符串。

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

js处理大的数值会缺少,主要因为js有最大安全数,超过了这个数就失去精度了。所以要解决这个问题 我们考虑到使用插件:

1.vue开发前端的有时候后台返回的是数字 获取时候就失去精度了 这个时候可以使用

包的处理:  其实就是把"大数"转换为一个js字符串对象,这样js就可以识别了,当用到的时候就可以使用这个对象.tostring转换成字符串

下载:

npm install json-bigint -S
// 导入大数处理的包
import bigInt from 'json-bigint'
const transBigInt = data => {
    try {
      // 尝试进行大数处理
      // 优选方案
      return bigInt.parse(data)
    } catch {
      // 大数处理失败,单纯的进行 JSON -> 对象的转换
      // 兜底的方案
      return JSON.parse(data)
    }
  }
axios.defaults.transformResponse= [transBigInt]  // 对服务器响应回来的数据,进行预处理transformResponse: [transBigInt]      

这样接口返回的数据就不丢失精度了 

 对数据处理之后想要计算比如计算和 用bignumber插件 下载:

npm install bignumber.js  

自己写了一个格式化金额保留两位的函数和求和的 传递的参数都需要是数字都需要提前转成字符串 不然会丢失精度

import  Bignumber from "bignumber.js";
const bigObjFN={
  //取值金额格式化个数
  formatNumber(num,len=2){
    //格式化金额
    return new Bignumber(num).toFormat(len) 
  },
  //大数据计算求和
  add(arg1=0,arg2=0){
    return new Bignumber(arg1).plus(arg2).toString();
  }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值