js中的大数问题

有时候后端返回的id是一串很长的数字

  • 但是js中能够表示的数组最大的范围: 2的-53次方到2的53次方之间

  • 如果数字超过了这个范围就会出现精度丢失的问题

  • 有的项目中的文章的id就超出了范围。所以在json转成对象的时候,id就不正确了。

  • 如何解决:需要使用json-bigint库

1. 安装  yarn add json-bigint
2. 引入json-bigint

var res = '{"id": 1326325328917823488, "name": "zs"}'
console.log('1', JSON.parse(res).id)
console.log('2', JSONbig.parse(res).id.toString())

大数问题最终解决方案

安装json-bigint

yarn add json-bigint

在request.js中控制axios转换响应的逻辑

import JSONbig from 'json-bigint'

const instance = axios.create({
  // baseURL: 'http://ttapi.research.itcast.cn/',
  baseURL,
  timeout: 3000,
  // 自定义响应的处理
  transformResponse: [function (data) {
    // 对 data 进行任意转换处理  data就是后端返回的原始字符串
    try {
      return JSONbig.parse(data)
    } catch {
      return data
    }
  }]
})

将来使用id的时候,需要记住,id是一个对象类型了,需要toString()

<van-cell v-for="item in list" :key="item.art_id.toString()"/>
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值