为什么后端接口返回数字类型1.00前端会取到1?

news/2025/3/27 5:11:50/

这得从axios中得默认值说起:

Axios 的 transformResponse


axios 在接收到服务器的响应后,会通过一系列的转换函数(transformResponse)来处理响应数据,使其适合在应用程序中使用。默认情况下,axios 的 transformResponse 包含以下步骤:

  1. 解析 JSON 数据:使用 JSON.parse 将响应的 JSON 字符串转换为 JavaScript 对象。
  2. 转换数据:根据响应的 Content-Type,可能进行其他转换(如将 XML 转换为对象)。
  3. 返回数据:最终返回处理后的数据供应用程序使用。

默认的 transformResponse

javascript">// node_modules/axios/lib/defaults.js
const defaults = {// 其他默认配置...transformResponse: [function transformResponse(data) {// 对 data 进行任意转换处理if (typeof data === 'string') {try {data = JSON.parse(data);} catch (e) { /* 忽略解析错误 */ }}return data;}],// 其他默认配置...
};

在这个过程中,JSON.parse 将 JSON 字符串转换为 JavaScript 对象。然而,JavaScript 的 Number 类型在处理某些数字时会自动去除不必要的尾随零,例如将 12.00 转换为 12

为什么 JSON.parse 会舍去小数点后的零?

是因为 JSON.parse 将数字字符串解析为 JavaScript 的 Number 类型。在 JavaScript 中,12.00 和 12 被认为是相等的数值,因此 JSON.parse 会自动优化表示方式,去掉不必要的尾随零。这是 JavaScript 的预期行为,但在某些需要保留特定小数位数的场景下,这可能会导致问题。

解决方案-------------------------------------

1. 后端返回字符串类型的数据

最直接的方法是让后端在返回JSON数据时,将需要保留小数位数的数字字段作为字符串返回。这样,前端接收到的数据将保留原始的小数点后零。

后端示例(以Java为例):​

java">public class ResponseData {@JsonFormat(shape = JsonFormat.Shape.STRING)private String number;// getters and setters
}

返回的JSON:​

javascript">{"number": "12.00"
}

前端处理:​

javascript">axios.get('/api/your-api').then(response => {const numberString = response.data.number; // "12.00"const number = parseFloat(numberString); // 如果需要数值类型,可以转换const formattedNumber = number.toFixed(2); // "12.00"
});


2. 自定义transformResponse

如果无法修改后端返回的数据格式,可以在axios的配置中自定义transformResponse,在数据被解析为JavaScript对象之前,对特定字段进行处理,确保数字以字符串形式保留小数点后的零。

示例代码:​

javascript">import axios from 'axios';const axiosInstance = axios.create({transformResponse: [function (data) {let parsedData;try {parsedData = JSON.parse(data, (key, value) => {if (typeof value === 'number' && Number.isFinite(value)) {return value.toFixed(2);}return value;});} catch (e) {return data;}return parsedData;}],
});axiosInstance.get('/api/your-api').then(response => {console.log(response.data); // 数字字段将以字符串形式保留两位小数
});


3. 在前端手动处理数字格式

如果后端返回的数字是数值类型,且你只需要在前端展示时保留小数点后的零,可以在渲染时进行格式化,而不改变原始数据。

示例代码(Vue.js):

<template><div>格式化后的数字: {{ formattedNumber }}</div>
</template><script>
export default {data() {return {number: 12.00 // 假设这是从后端获取的数字};},computed: {formattedNumber() {return this.number.toFixed(2); // "12.00"}}
};
</script>


4. 使用字符串处理库

如果需要更复杂的数字格式化,可以使用第三方库如numeral.jsaccounting.js来处理数字格式。

使用numeral.js的示例:​

javascript">npm install numeral
javascript">import axios from 'axios';
import numeral from 'numeral';axios.get('/api/your-api').then(response => {const number = response.data.number; // 假设是数值类型 12const formattedNumber = numeral(number).format('0.00'); // "12.00"console.log(formattedNumber);
});

总结-------------------------------------------------------

为了避免前后端交互中数字格式的问题,最佳实践是:

  • 后端返回字符串类型的数据,明确保留小数点后的零。   -----首选
  • 自定义transformResponse,在数据解析阶段对特定字段进行处理。
  • 前端进行格式化,在展示时根据需要格式化数字。

http://www.ppmy.cn/news/1582920.html

相关文章

安铂克科技APMQS20高性能模块级射频/微波信号发生器 信号源模块

APMQS20微波信号源模块简述&#xff1a; 安铂克科技APMQS20微波信号源模块提供仪器级性能&#xff0c;增强功能和高效节能的同时&#xff0c;尺寸更小&#xff0c;价格实惠。它的设计结合了低相位噪声和快速切换能力&#xff0c;覆盖了从8kHz至20GHz的宽频范围。信号的低杂散和…

基于python+django的图书借阅网站-图书借阅管理系统源码+运行步骤

该系统是基于pythondjango开发的在线图书借阅管理系统。系统适合场景&#xff1a;大学生、课程作业、系统设计、毕业设计。 演示地址 前台地址&#xff1a; http://book.gitapp.cn 后台地址&#xff1a;http://book.gitapp.cn/#/admin 后台管理帐号&#xff1a; 用户名&…

【二分查找 树状数组 差分数组 离散化 】P6172 [USACO16FEB] Load Balancing P|省选-

本文涉及的基础知识点 C二分查找 C差分数组 【C】树状数组的使用、原理、封装类、样例 P6172 [USACO16FEB] Load Balancing P 题目背景 本题与 银组同名题目 在题意上一致&#xff0c;唯一的差别是数据范围。 题目描述 Farmer John 的 N N N 头奶牛&#xff08; 1 ≤ N …

Python 变量作用域、global 关键字与闭包作用域深度解析 第三部分

## 三、闭包作用域的存在原因及适用场景 ### 3.1 闭包作用域存在的原因 #### 3.1.1 数据封装与隐藏 闭包可以把数据封装在外部函数的作用域中&#xff0c;只有内部函数能够访问这些数据&#xff0c;这有助于实现数据的隐藏和保护。 python def counter(): count 0 def incre…

Select多路转接

在之前的文章中&#xff0c;我们介绍了五种IO模型。曾提到过&#xff0c;效率最高的模型一般是多路转接&#xff0c;即同时有多个socked套接字在等待资源就绪&#xff0c;将各自的等待时间重叠&#xff0c;从而减少等待时间的占比&#xff0c;提高效率。 那么在Linux系统中就给…

Vue 项目编译错误:These dependencies were not found,To install them, you can run...

问题与处理策略 问题描述 运行一个 Vue 项目时&#xff0c;报如下错误 ERROR Failed to compile with 47 errors …

HRP方法全文总结与模型流程解析

背景与问题 传统二次优化方法&#xff08;如Markowitz的CLA&#xff09;存在三大问题&#xff1a; 不稳定性&#xff1a;协方差矩阵的高条件数导致逆矩阵计算误差放大&#xff0c;权重剧烈波动。 集中性&#xff1a;优化结果过度集中于少数资产&#xff0c;易受个体风险冲击。…

C#从入门到精通(1)

目录 第一章 C#与VS介绍 第二章 第一个C#程序 &#xff08;1&#xff09;C#程序基本组成 1.命名空间 2.类 3.Main方法 4.注释 5.语句 6.标识符及关键字 &#xff08;2&#xff09;程序编写规范 1.代码编写规则 2.程序命名方法 3.元素命名规范 第三章 变量 &…