axios解决后端传来的id太长导致精度丢失(超过16位的数字会变成0000)的问题

 办法一:让后端把id传成字符串类型;

办法二:用jsonBig转换为bigInt数字类型:

1.在项目根目录打开命令行输入命令安装jsonBig插件:

npm install json-bigint@1.0.0

2.在封装的请求中使用插件,核心是在创建sxios实例的时候假如transformResponse这个配置项,可以拦截接口返回的内容进行处理(因为默认会使用JSON.parse()解析从后端的来的数据),再用json-bigint插件把长类型数字解析成字符串,解析失败就代表没有长数字可解析,使用JSON.parse()解析

import axios from 'axios';
import jsonBig from 'json-bigint'


//利用axios对象的方法create,去创建一个axios实例
const api = axios.create({
    //基础路径
    baseURL: "http:xxxxxxxxx", // 后端地址
    timeout: 60000, // 请求超时时间
    transformResponse: [function (data) {//transformResponse这个配置项可以拦截接口返回的内容进行处理
        try {
            // 如果大数字类型转换成功则返回转换的数据结果
            return jsonBig.parse(data);
        } catch (err) {
            // 如果转换失败,代表没有长数字可转,正常解析并返回
            return JSON.parse(data)
        }
    }]
})



//最后一步 暴露出去实例导出
export default api

3.使用:

使用的时候用id.toString()方法把bigInt类型的数字变成字符串类型就能使用了

最近更新

  1. TCP协议是安全的吗?

    2024-05-12 07:12:06       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-05-12 07:12:06       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-05-12 07:12:06       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-05-12 07:12:06       20 阅读

热门阅读

  1. 【YOLOv9算法原理简介】

    2024-05-12 07:12:06       11 阅读
  2. unix C之环境变量

    2024-05-12 07:12:06       15 阅读
  3. react配置@指向src目录

    2024-05-12 07:12:06       10 阅读
  4. ActiViz中的图像平滑

    2024-05-12 07:12:06       12 阅读
  5. Linux运行级别介绍

    2024-05-12 07:12:06       51 阅读
  6. Hive大表join大表如何调优

    2024-05-12 07:12:06       14 阅读
  7. docker安装的es配置密码认证

    2024-05-12 07:12:06       13 阅读
  8. 手机App防沉迷系统-算法

    2024-05-12 07:12:06       11 阅读
  9. 【汽车功能安全】NXP SKXX之STCU

    2024-05-12 07:12:06       12 阅读
  10. 算法训练营day36

    2024-05-12 07:12:06       32 阅读