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

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

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

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

javascript 复制代码
npm install json-bigint@1.0.0

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

javascript 复制代码
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.使用:

javascript 复制代码
使用的时候用id.toString()方法把bigInt类型的数字变成字符串类型就能使用了
相关推荐
海特伟业13 小时前
隧道调频广播覆盖-隧道调频广播无线覆盖系统建设要点、难点分析与解决应对
运维·设计模式
中国IT13 小时前
第3章:Docker与传统虚拟化比较
运维·docker·容器
九硕智慧建筑一体化厂家13 小时前
DDC:看似普通的存在,在楼宇自控系统中却主宰智能建筑高效运行?
大数据·运维·人工智能·网络协议·制造·设计规范
原来是猿13 小时前
Linux - 基础IO【下】
linux·运维·服务器
淡泊if13 小时前
eBPF 实战:一次诡异的 Nginx 高延迟,我用 5 分钟在内核里找到了真凶
java·运维·nginx·微服务·ebpf
志栋智能13 小时前
安全超自动化的终极目标:实现自适应安全防护
运维·人工智能·安全·自动化
xyd陈宇阳13 小时前
面向网络协议初学者的入门指南
linux·运维·网络协议
慧天城寻14 小时前
H3C巡检命令与避坑技巧
运维·网络·运维开发
tnuly14 小时前
Linux 云计算运维入门:从 Socket 底层到 Apache 实战,HTTP 服务全知识点拆解
运维
兮动人14 小时前
Linux 云服务器部署 OpenClaw 全攻略:从环境搭建到 QQ 机器人集成
linux·服务器·机器人·openclaw