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类型的数字变成字符串类型就能使用了
相关推荐
b***25115 分钟前
比斯特自动化动力电池组半自动生产线的工艺革新与效率提升
运维·自动化
打码人的日常分享16 分钟前
新型智能建造解决方案
运维·人工智能·安全·系统安全·制造
默|笙17 分钟前
【Linux】线程互斥与同步_同步(2)_环形队列
linux·运维·服务器
cui_ruicheng25 分钟前
Linux IO入门(一):从C语言IO到文件描述符
linux·运维·c语言
北京耐用通信26 分钟前
工业通信升级:耐达讯自动化CAN转EtherCAT网关的高效落地方案
服务器·人工智能·科技·物联网·自动化·信息与通信
青花瓷34 分钟前
ubuntu22.04的ibus中文输入法的安装
运维·ubuntu
Wenweno0o36 分钟前
CC-Switch & Claude 基于 Linux 服务器安装使用指南
linux·服务器·claude code·cc-switch
志栋智能1 小时前
当巡检遇上超自动化:一场运维质量的系统性升级
运维·服务器·网络·数据库·人工智能·机器学习·自动化
主角1 71 小时前
Keepalived高可用与负载均衡
运维·负载均衡
星辰徐哥1 小时前
CDN工作原理:节点缓存、智能调度,减少跨网传输延迟
服务器·缓存·php