element ui前端小数计算精度丢失的问题如何解决?

文章目录

  • 前言
  • 一、什么是精度丢失?
    • 产生精度丢失的原因
    • 如何避免或减少精度丢失的影响
  • 二、实际项目开发实例举例
    • 以项目预算模块为例
    • 如何解决精度丢失
  • 总结


前言

在《工程投标项目管理系统》项目开发中工程项目预算、成本管理、财务管理等模块的开发中不可避免的要和金融数字打交道,数字的计算 vue 总是出现精度丢失的困惑,解决这个问题其实很简单,有条件的同学可以自己封装函数,没有条件的同学懒人就用懒方法。小编虽懒,使用高人封装的decimal.js方法,爽的一逼,节约时间用于陪女朋友去喝咖啡何乐而不美🌹🤣🌹🤣🌹


一、什么是精度丢失?

  • 在计算机中,小数是以二进制的形式存储的。有些十进制小数无法精确地转换为二进制小数,在进行数值计算时就会产生精度丢失的问题。例如,十进制的 0.1 在二进制中是一个无限循环小数。在计算机内存中,由于存储位数的限制,只能近似地表示这个数,这就导致了精度的损失。
    当进行多个小数的运算,如加法、减法、乘法、除法等操作时,这种精度误差可能会累积,从而使最终结果与预期的数学精确结果产生偏差。

产生精度丢失的原因

1、二进制与十进制的转换问题
计算机底层是基于二进制进行数据存储和运算的。像十进制的分数1/3在十进制下是无限循环小数,同样,有些十进制小数在转换为二进制时也是无限循环小数。以为例,将其转换为二进制的计算过程如下:

  • 0.1x2=0.2 整数部分为0;
  • 0.2x2=0.4 整数部分为0;
  • 0.4x2=0.8 整数部分为0;
  • 0.8x2=1.6 整数部分为1;
  • 0.6x2=1.2 整数部分为1;

以此类推,会发现转换为二进制是,是一个无限循环小数。计算机在存储时如果只能保留有限的位数,就会产生精度误差。
2、浮点数的存储格式限制
计算机中常用的浮点数(如单精度浮点数和双精度浮点数)有其特定的存储格式。以 IEEE 754 标准的单精度浮点数为例,它用 32 位来存储一个浮点数,其中包括 1 位符号位、8 位指数位和 23 位尾数位。这种有限的位数限制了能够精确表示的数值范围和精度。
例如,当两个非常接近的小数相减时,由于浮点数的精度限制,可能会得到不准确的结果。假设,,在理论上,但在计算机中由于精度问题,可能会得到一个略微偏离这个值的结果。

如何避免或减少精度丢失的影响

1、使用高精度计算库
对于一些对精度要求极高的计算场景,如金融计算等,可以使用高精度计算库。
2、适当的数值缩放
在一些情况下,可以通过适当的数值缩放来减少精度丢失的影响。例如,在处理货币金额时,如果金额单位是元,可以将其转换为分来进行计算。这样就可以使用整数进行计算,避免了小数计算带来的精度问题。
3、误差范围判断
对于一些不要求绝对精确,但要求在合理误差范围内的计算,可以设定一个允许的误差范围。
例如,当比较两个浮点数是否相等时,不直接使用a==b,而是判断|a-b|<e,其中e是一个很小的允许误差值,如 1e-9。

二、实际项目开发实例举例

以项目预算模块为例

项目的预算一般分为名称、规格、单价、数量,总价即为单价和数量相乘的鸡,别管什么丫,下面截图不难看出计算结果,无限接近实际值,近在咫尺永恒于咫尺,这就纳闷,(´・_・`) 会计看见就会懵圈,我单位的会计是个温顺优雅,肤色如水银的大美女,小编暗恋她多时了,不知用什么优雅的方式表白,心涌澎湃却又猥琐至极,其实真正懵圈的是我这个可怜而又孤独的猿人;
在这里插入图片描述

给你看看上图所对应我的屎坨代码,太喽了,搓的一比!

   <el-table-column label="单价" prop="dePrice" width="180"><template slot-scope="scope"><el-form-item :prop="'oaBudgetDetailList.' + scope.$index + '.dePrice'" :rules="subRules.de_price" label-width="0"><el-input v-model="scope.row.dePrice" placeholder="请输入单价" @input="handleMouseLeave"/></el-form-item></template></el-table-column><el-table-column label="数量" prop="deNumber" width="180"><template slot-scope="scope"><el-form-item :prop="'oaBudgetDetailList.' + scope.$index + '.deNumber'" :rules="subRules.de_number" label-width="0"><el-input v-model="scope.row.deNumber" placeholder="请输入数量" @input="handleMouseLeave"/></el-form-item></template></el-table-column><el-table-column label="总价" width="180"><template slot-scope="scope"><div style="background-color: #cccccc;padding: 6px;">{{multiplyWithPrecision(Number(scope.row.dePrice), Number(scope.row.deNumber))}}</div></template></el-table-column>

鼠标移开后执行了方法:

    /**计算两个数相乘**/multiplyWithPrecision(num1, num2) {const total = num1 * num2;return Number(total);}

你铁定没看懂吧,这也许是我多年找不到女朋友的最直接的原因,代码写的喽,女孩、女人、妇女、大妈、奶奶根本不看你一眼,我TM太难了🤦‍♂️,在爱情的云端,希望高人指点,早日摆脱单身狗,小编确实太寂寞,美好的渴望总是经常回味会计从身边走过的那股浓郁芳香的风,我愿随风潜入夜,却总润物细无声。

如何解决精度丢失

terminal 进入到 ruoyi-ui 根目录执行下面命令行:

npm install --save decimal.js

在这里插入图片描述
node_modules 目录就多一个文件:

在这里插入图片描述
引入

import Decimal from "decimal.js";

将计算方法改造如下:

    /**计算两个数相乘**/multiplyWithPrecision(num1, num2) {return Decimal.mul(num1, num2).toNumber();}

这个代码,你应该可以看得懂吧,看不懂你是装不懂吧。优雅到总算能在产品经理面前甩甩发型了,从来很少和小编说话的会计既然笑着竖起大拇指!没想到技术总监既然把项目中的财务管理模块的开发分给了小编,这可把小编乐坏了,终于有机会和会计对接业务了,我美了美了美了、我醉了醉了醉了,我爱编程不爱加班的历史颠覆了;🌹🌹🌹🌹🌹🌹🌹🌹🌹

最终项目既然开源了,小编为您呈上,支持下多多 star!您的支持是我源泉的动力。

开源地址:https://gitee.com/xnqysabout/ry-vue-flowable-xg


总结

解决前端小数计算精度丢失的问题,非常简单,Decimal库能有效解决此问题,它内部以高精度方式存储和处理数字,摒弃二进制浮点数弊端。加、减、乘、除等运算能精准得到期望结果。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/204.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

《分布式光纤测温:解锁楼宇安全的 “高精度密码”》

在楼宇建筑中&#xff0c;因其内部空间庞大&#xff0c;各类电器设施众多&#xff0c;如何以一种既高效又稳定&#xff0c;兼具低成本与高覆盖特性的方式&#xff0c;为那些关键线路节点开展温度监测&#xff0c;是目前在安全监测领域一项重点研究项目&#xff0c;而无锡布里渊…

油猴支持阿里云自动登陆插件

遇到的以下问题&#xff0c;都已在脚本中解决&#xff1a; 获取到的元素赋值在页面显示&#xff0c;但是底层的value并没有改写&#xff0c;导致请求就是获取不到数据元素的加载时机不定&#xff0c;尤其是弱网情况下&#xff0c;只靠延迟还是有可能获取不到&#xff0c;且登陆…

代码随想录算法训练营第3天(链表1)| 203.移除链表元素 707.设计链表 206.反转链表

一、203.移除链表元素 题目&#xff1a;203. 移除链表元素 - 力扣&#xff08;LeetCode&#xff09; 视频&#xff1a;手把手带你学会操作链表 | LeetCode&#xff1a;203.移除链表元素_哔哩哔哩_bilibili 讲解&#xff1a;代码随想录 注意&#xff1a; 针对头结点和非头结点的…

如何实现多级缓存?

本文重点说一说在Java应用中&#xff0c;多级缓存如何实现。 多级缓存是比较常见的一种性能优化的手段&#xff0c;一般来说就是本地缓存分布式缓存。 本地缓存一般采用Caffeine和Guava&#xff0c;这两种是性能比较高的本地缓存的框架。他们都提供了缓存的过期、管理等功能。…

网工_网络体系结构

2024.01.09&#xff1a;网络工程学习笔记&#xff08;网工老姜&#xff09; 第1节 网络体系结构 1.1 计算机一切皆011.2 网络协议1.3 协议的分层模型1.4 主机1向主机2发送数据过程1.5 本章小结 1.1 计算机一切皆01 在计算机内部&#xff0c;所有的数据最终都是以01的方式存在的…

3DGabor滤波器实现人脸特征提取

import cv2 import numpy as np# 定义 Gabor 滤波器的参数 kSize 31 # 滤波器核的大小 g_sigma 3.0 # 高斯包络的标准差 g_theta np.pi / 4 # Gabor 函数的方向 g_lambda 10.0 # 正弦波的波长 g_gamma 0.5 # 空间纵横比 g_psi np.pi / 2 # 相位偏移# 生成 Gabor 滤…

如何稳定使用 O1 / O1 Pro,让“降智”现象不再困扰?

近期&#xff0c;不少朋友在使用 O1 或 O1 Pro 模型时&#xff0c;都会碰到“降智”或“忽高忽低”的智力波动&#xff0c;比如无法识图、无法生成图片、甚至回答准确度也不稳定。面对这些问题&#xff0c;你是不是也感到头疼呢&#xff1f; 为了找到更可靠的解决办法&#xf…

关于物联网的基础知识(二)——物联网体系结构分层

成长路上不孤单&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a; 【14后&#x1f60a;///计算机爱好者&#x1f60a;///持续分享所学&#x1f60a;///如有需要欢迎收藏转发///&#x1f60a;】 今日分享关于物联网的基础知识&#xff08;二&a…

Notepad++上NppFTP插件的安装和使用教程

一、NppFTP插件下载 图示是已经安装好了插件。 在搜索框里面搜NppFTP&#xff0c;一般情况下&#xff0c;自带的下载地址容易下载失败。这里准备了一个下载连接&#xff1a;Release v0.29.10 ashkulz/NppFTP GitHub 这里我下载的是x86版本 下载好后在nodepad的插件里面选择打…

Kali系统(Debian 10.3) 遇到的问题

目录 问题一&#xff1a;非问题 kali 基础官网与安装 问题二&#xff1a; 问题三&#xff1a; Kali系统 MySQL问题Cant connect to local MySQL server through socket /run/mysqld/mysqld.sock (2) 问题四&#xff1a;重新安装MySQL 也就是MariaDB(MariaDB 含 MySQL相关…

蓝桥杯嵌入式速通(1)

1.工程准备 创建一文件夹存放自己的代码&#xff0c;并在mdk中include上文件夹地址 把所有自身代码的头文件都放在headfile头文件中&#xff0c;之后只需要在新的文件中引用headfile即可 headfile中先提前可加入 #include "stdio.h" #include "string.h"…

C# GDI+的DrawString无法绘制Tab键的现象

【啰嗦2句】 现在用C#的人很少了吧&#xff1f;GDI更少了吧&#xff1f;所以这个问题估计也冷门。没关系&#xff0c;分享给特定需要的人也不错。 【问题现象】 工作中开发了一个报告编辑器&#xff0c;实现图文排版等功能&#xff0c;用着没什么问题&#xff0c;直到有一天…

Linux (CentOS) 安装 Docker 和 Docker Compose

&#x1f680; 作者主页&#xff1a; 有来技术 &#x1f525; 开源项目&#xff1a; youlai-mall ︱vue3-element-admin︱youlai-boot︱vue-uniapp-template &#x1f33a; 仓库主页&#xff1a; GitCode︱ Gitee ︱ Github &#x1f496; 欢迎点赞 &#x1f44d; 收藏 ⭐评论 …

计算机网络(六)应用层

6.1、应用层概述 我们在浏览器的地址中输入某个网站的域名后&#xff0c;就可以访问该网站的内容&#xff0c;这个就是万维网WWW应用&#xff0c;其相关的应用层协议为超文本传送协议HTTP 用户在浏览器地址栏中输入的是“见名知意”的域名&#xff0c;而TCP/IP的网际层使用IP地…

高级软件工程-复习

高级软件工程复习 坐标国科大&#xff0c;下面是老师说的考试重点。 Ruby编程语言的一些特征需要了解要能读得懂Ruby程序Git的基本命令操作知道Rails的MVC工作机理需要清楚&#xff0c;Model, Controller, View各司什么职责明白BDD的User Story需要会写&#xff0c;SMART要求能…

【计算机网络】lab3 802.11 (无线网络帧)

&#x1f308; 个人主页&#xff1a;十二月的猫-CSDN博客 &#x1f525; 系列专栏&#xff1a; &#x1f3c0;计算机网络_十二月的猫的博客-CSDN博客 &#x1f4aa;&#x1f3fb; 十二月的寒冬阻挡不了春天的脚步&#xff0c;十二点的黑夜遮蔽不住黎明的曙光 目录 1. 前言 2.…

大语言模型训练的数据集从哪里来?

继续上篇文章的内容说说大语言模型预训练的数据集从哪里来以及为什么互联网上的数据已经被耗尽这个说法并不专业&#xff0c;再谈谈大语言模型预训练数据集的优化思路。 1. GPT2使用的数据集是WebText&#xff0c;该数据集大概40GB&#xff0c;由OpenAI创建&#xff0c;主要内…

Unity Burst详解

【简介】 Burst是Unity的编译优化技术&#xff0c;优化了从C#代码编译成Native代码的过程&#xff0c;经过编译优化后代码有更高的运行效率。 在Unity中使用Burst很简单&#xff0c;在方法或类前加上[BurstCompile]特性即可。在构建时编译代码的步骤&#xff0c;Burst编译器会…

【经典神经网络架构解析篇】【1】LeNet网络详解:模型结构解析、优点、实现代码

《------往期经典推荐------》 一、AI应用软件开发实战专栏【链接】 项目名称项目名称1.【人脸识别与管理系统开发】2.【车牌识别与自动收费管理系统开发】3.【手势识别系统开发】4.【人脸面部活体检测系统开发】5.【图片风格快速迁移软件开发】6.【人脸表表情识别系统】7.【…

数据结构之双向链表

目录 双向链表的基本概念和结构 初始化 尾插 头插 尾删 头删 查找 在指定位置之后插入 删除指定位置节点 判空 销毁 完整代码 测试代码 双向链表的基本概念和结构 双向链表&#xff08;Doubly Linked List&#xff09;‌是一种链式存储结构&#xff0c;每个节点除…