利用json-bigint处理后台数据大数字问题

  • Post author:
  • Post category:其他




json-bigint

GitHub网址:

https://github.com/sidorares/json-bigint


当我们在写项目的时候调用后台接口的地址需要接收一个id值例如:(id:9223372036854776000)



JavaScript 能够准确表示的整数范围在

-2^53



2^53

之间(不含两个端点),超过这个范围,无法精确表示这个值,这使得 JavaScript 不适合进行科学和金融方面的精确计算



浏览器会默认解析得到数值与原数值不匹配导致404问题



解决这个问题我们使用第三方插件JSON-BigInt


1. 安装


npm i json-bigint


2. 导入


var JSONbig = require('json-bigint')


3. 使用



JSONbig.parse()


将json格式字符串转化为对象与JSON.parse()类似

var json = '{ "value" : 9223372036854775807}'
// 将json字符串转为对象
console.log(JSON.parse(json))// 9223372036854776000
console.log(JSONbig.parse(json).value.toString())// 是一个对象 需要toSring() 9223372036854776000


JSONbig.stringify()


将对象转化为json格式字符串与JSON.stringify()类似

// 将对象还原为json格式的字符串
console.log(JSON.stringify(JSONbig.parse(json))) // {"value":"9223372036854775807"}改变了原数据的值的数据类型
console.log(JSONbig.stringify(JSONbig.parse(json)))// {"value":9223372036854775807} 没有改变原数据

通过 Axios 请求得到的数据都是 Axios 处理(JSON.parse)之后的,我们应该在 Axios 执行处理之前手动使用 json-bigint 来解析处理。Axios 提供了自定义处理原始后端返回数据的 API:

transformResponse

import axios from 'axios'
var jsonBig  = require('json-bigint')


const request = axios.create({
  baseURL: 'http://ttapi.research.itcast.cn/', // 接口基础路径

  // transformResponse 允许自定义原始的响应数据(字符串)
  transformResponse: [function (data) {
    try {
      // 如果转换成功则返回转换的数据结果
      return jsonBig.parse(data)
    } catch (err) {
      // 如果转换失败,则包装为统一数据格式并返回
      return {
        data
      }
    }
  }]
})

export default request



版权声明:本文为weixin_44389562原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。