当前位置: 首页 > article >正文

数据库自增 id 过大导致前端时数据丢失

可以看到,前端响应参数是没有丢失精度的

 但是在接受 axios 请求参数时出现了精度丢失

解决方案一:改变 axios 字符编码

axios.defaults.headers['Content-Type'] = 'application/json;charset=UTF-8';

 未解决

解决方案二:手动使用 json.parse() 方法还原响应数据

axios.defaults.transformResponse = [];
const articles = ref(null);

function safeJsonParse(jsonStr) {
    const regex = /"(\w+)":([^,}]+)/g;
    let match;
    let result = '';
    let index = 0;
    while ((match = regex.exec(jsonStr))!== null) {
        const key = match[1];
        let value = match[2];
        if (key === 'id' && /^\d+$/.test(value)) {
            const numValue = Number(value);
            if (numValue > Number.MAX_SAFE_INTEGER) {
                value = `"${value}"`;
            }
        }
        result += jsonStr.slice(index, match.index) + `"${key}":${value}`;
        index = regex.lastIndex;
    }
    result += jsonStr.slice(index);
    return JSON.parse(result);
}

const getPostArticles = async () => {
    const res = await axios({
        method: 'post',
        url: '/articles',
        data: {
            page: 1,
            pageSize: 10
        }
    });
    const parsedData = safeJsonParse(res.data); // 手动解析响应数据
    console.log('手动解析后的原始响应数据:', parsedData);
    articles.value = parsedData.data;
    console.log('articles数组为',articles);
};

成功拿到一整个响应的对象,数据没有丢失

但是引发了新的问题,在跳转到文章详情页面后,文章详情发送请求成功却没有正确赋值

找到错误点,整个项目是用的同一个 axios 实例对象,当这个对象开启手动处理响应的 json 参数后,每一个 axios 请求都需要手动处理了

解决方案,请求的 axios 独立出来,选择使用新创建的 axios 实例来发送异步请求 

import axios from 'axios';

// 创建自定义的 axios 实例
const customAxios = axios.create({
  baseURL: 'http://localhost:8888',
  timeout: 5000
});
//开启自定义处理响应
customAxios.defaults.transformResponse = [];

// 获取文章列表的函数
const getPostArticles = async () => {
  try {
    const res = await customAxios.post('/articles', {
      page: 1,
      pageSize: 10
    });
    const parsedData = safeJsonParse(res.data);
    console.log('手动解析后的原始响应数据:', parsedData);
    articles.value = parsedData.data;
    console.log('articles 数组为', articles);
  } catch (error) {
    console.error('获取文章列表失败:', error);
  }
};

这个 axios 实例只为这一个页面服务


http://www.kler.cn/a/459814.html

相关文章:

  • Python 列表的高级索引技巧
  • 【74LS160+74LS273DW锁存器8位的使用频率计】2022-7-12
  • 《经典力学》笔记
  • vscode中设置默认格式化工具pretter
  • SpringBoot整合篇 05、Springboot整合Redission
  • LeetCode - 初级算法 数组(只出现一次的数字)
  • 活动预告 |【Part1】Microsoft Azure 在线技术公开课:数据基础知识
  • Debian12使用RKE2离线部署3master2node三主两从的k8s集群详细教程
  • 通过iptables限制docker 容器的运行端口
  • Spring Boot 项目 与 其他依赖版本兼容对应表
  • K8S网络流量路径
  • 数据库系列之分布式数据库下误删表怎么恢复?
  • UE5材质节点CameraDepthFade
  • Kafka安全优化文档:漏洞修复到安全加固
  • 【已解决】PDF文档有密码怎么办(2024新)免费在线工具PDF2Go
  • 项目需求分析流程
  • 用AI生成PPT,告别繁琐,一键生成高效方案
  • 深入解析 Conda 安装的默认依赖包及其作用:conda create安装了哪些包(中英双语)
  • Spring Boot 中 RabbitMQ 的使用
  • Java虚拟机——JVM
  • 安装与配置
  • 【Scala】图书项目系统代码演练3.1/BookService
  • 【信号滤波 (下)】采样条件,多种滤波算法对比(Matlab/C++)
  • 【技术实战】R语言统计分析与可视化从入门到精通
  • 【C#】int与byte[]数组互转
  • Hugging Face Dataset的 dataset_info.json 文件详解