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类型的数字变成字符串类型就能使用了
相关推荐
济617几秒前
linux 系统移植(第二十一期)---- 完善BusyBox构建的根文件系统---- Ubuntu20.04
linux·运维·服务器
历程里程碑3 分钟前
Linux 9:GCC编译全流程详解
linux·运维·服务器·c语言·笔记·编辑器·vim
赋创小助手6 分钟前
Maia 200 技术拆解:微软云端 AI 推理加速器的设计取舍
服务器·人工智能·科技·深度学习·神经网络·microsoft·自然语言处理
他人是一面镜子,保持谦虚的态度7 分钟前
ubuntu 18.04 压缩 激光雷达点云和图像 topic,并录制bag 数据包
linux·运维·ubuntu
2501_945837439 分钟前
腾讯云边缘容器服务,云边协同打通云原生最后一公里
服务器
爱吃生蚝的于勒10 分钟前
【Linux】进程信号的保存(二)
linux·运维·服务器·c语言·数据结构·c++·算法
HalvmånEver11 分钟前
Linux:线程的概念、与进程区别及内核实现(线程一)
java·linux·运维
Linux蓝魔13 分钟前
mysql-redis-kafka-es-ngnix安装调试
linux·服务器·mysql·kafka·es
weixin_4492900115 分钟前
EverMemOS Docker 运行环境搭建指南
运维·docker·容器
春日见16 分钟前
C++单例模式 (Singleton Pattern)
java·运维·开发语言·驱动开发·算法·docker·单例模式