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 小时前
有哪些开源的直播云服务器安全防护方案?
运维·服务器·云计算
C_心欲无痕14 小时前
nginx - 开启 gzip 压缩
运维·前端·nginx
开开心心_Every14 小时前
安卓后台录像APP:息屏录存片段,行车用
java·服务器·前端·学习·eclipse·edge·powerpoint
qq_3168377514 小时前
IP网段冲突 配置指定ip使用指定的网络接口发送,而不经过默认网关
服务器·网络·tcp/ip
王阿巴和王咕噜14 小时前
【WSL】安装并配置适用于Linux的Windows子系统(WSL)
linux·运维·windows
Xの哲學15 小时前
深入剖析Linux文件系统数据结构实现机制
linux·运维·网络·数据结构·算法
深圳市恒讯科技15 小时前
Linux 文件权限指南:chmod 755、644、drwxr-xr-x 解析
linux·服务器·xr
Wpa.wk15 小时前
性能测试工具 - JMeter工具组件介绍二
运维·经验分享·测试工具·jmeter·自动化·json
朝阳58115 小时前
Ubuntu 22.04 安装 Fcitx5 中文输入法完整指南
linux·运维·ubuntu
xingzhemengyou115 小时前
Linux taskset指令设置或查看进程的 CPU 亲和性
linux·服务器