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类型的数字变成字符串类型就能使用了
相关推荐
秋刀鱼 ..几秒前
第十一届金融创新与经济发展国际学术会议
运维·人工智能·科技·金融·自动化
Apibro16 分钟前
【LINUX】时区修改
linux·运维·服务器
遇见火星17 分钟前
Linux性能调优:使用strace来分析文件系统的性能问题
linux·运维·服务器·strace
槿花Hibiscus19 分钟前
C++基础:session实现和http server类最终组装
服务器·c++·http·muduo
倔强的小石头_20 分钟前
Python 从入门到实战(六):字典(关联数据的 “高效管家”)
java·服务器·python
@YDWLCloud38 分钟前
出海 APP 如何降低延迟?腾讯云国际版 GME 音视频深度评测
大数据·服务器·云计算·音视频·腾讯云
Splashtop高性能远程控制软件39 分钟前
索尼 Hawk-Eye(鹰眼)携手 Splashtop,远程技术赋能赛事运营革新
运维·网络·自动化·远程控制·远程桌面
九河云42 分钟前
华为云 ModelArts 赋能 AI 开发:从模型训练到边缘部署的全流程优化实践
服务器·人工智能·华为云·云计算
徐子元竟然被占了!!44 分钟前
Linux-Free
linux·运维
_OP_CHEN1 小时前
【Git原理与使用】(二)Git 配置与基本操作全攻略:从配置到实战,新手也能轻松上手!
linux·运维·git·版本管理·企业级组件·git基本操作·git配置