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

bignumber.js库,解决前端小数精度问题

bignumber.js 是一个 JavaScript 库,用于执行任意精度的十进制运算,特别适合处理大数字和需要高精度运算的情况。以下是一些 bignumber.js 库中的常用方法及其简要解释:

初始化

首先,你需要安装 bignumber.js 库:

npm install bignumber.js

然后在你的代码中引入:

const BigNumber = require('bignumber.js');

如果是ts中引入可以使用import

import BigNumber from 'bignumber.js';

常用方法

1. 创建一个 BigNumber 实例
const x = new BigNumber(123.456); // 从数字创建
const y = new BigNumber('123456.789e-3'); // 从字符串创建
const z = new BigNumber(x); // 从另一个 BigNumber 实例创建
2. 加法
const a = new BigNumber(0.1);
const b = new BigNumber(0.2);
const sum = a.plus(b); // 0.3
console.log(sum.toString()); // "0.3"
3. 减法
const difference = a.minus(b);
console.log(difference.toString()); // "-0.1"
4. 乘法
const product = a.times(b);
console.log(product.toString()); // "0.02"
5. 除法
const quotient = a.div(b);
console.log(quotient.toString()); // "0.5"
6. 取模
const remainder = a.mod(b);
console.log(remainder.toString()); // "0.1"
7. 幂运算
const pow = a.pow(2);
console.log(pow.toString()); // "0.01"
8. 平方根
const sqrt = a.sqrt();
console.log(sqrt.toString()); // "0.31622776601683793319988935444327"
9. 比较
const a = new BigNumber(3);
const b = new BigNumber(4);console.log(a.isGreaterThan(b)); // false
console.log(a.isLessThan(b)); // true
console.log(a.isEqualTo(b)); // false
10. 格式化输出
const a = new BigNumber(12345.6789);console.log(a.toFixed(2)); // "12345.68"
console.log(a.toExponential(2)); // "1.23e+4"
console.log(a.toPrecision(6)); // "12345.7"
11. 取整和取绝对值
const a = new BigNumber(-123.456);console.log(a.integerValue().toString()); // "-123"
console.log(a.absoluteValue().toString()); // "123.456"
12. 配置全局设置

你可以通过 BigNumber.config 来配置一些全局设置,比如精度和舍入模式:

BigNumber.config({ DECIMAL_PLACES: 10, ROUNDING_MODE: BigNumber.ROUND_HALF_UP });

示例总结

通过下面这个示例,你可以了解如何使用以上方法进行一些常见的运算:

const BigNumber = require('bignumber.js');// 创建 BigNumber 实例
const x = new BigNumber(0.1);
const y = new BigNumber(0.2);
// 实际在前端中0.1+0.2 是不等于0.3的,原因是前端的浮点数无法精确的表示小数// 加法
const sum = x.plus(y);
console.log(`Sum: ${sum.toString()}`); // "Sum: 0.3"// 减法
const difference = x.minus(y);
console.log(`Difference: ${difference.toString()}`); // "Difference: -0.1"// 乘法
const product = x.times(y);
console.log(`Product: ${product.toString()}`); // "Product: 0.02"// 除法
const quotient = x.div(y);
console.log(`Quotient: ${quotient.toString()}`); // "Quotient: 0.5"// 幂运算
const pow = x.pow(2);
console.log(`Power: ${pow.toString()}`); // "Power: 0.01"// 平方根
const sqrt = x.sqrt();
console.log(`Square Root: ${sqrt.toString()}`); // "Square Root: 0.31622776601683793319988935444327"// 比较
console.log(`Is x greater than y? ${x.isGreaterThan(y)}`); // false
console.log(`Is x less than y? ${x.isLessThan(y)}`); // true
console.log(`Is x equal to y? ${x.isEqualTo(y)}`); // false// 格式化输出
const a = new BigNumber(12345.6789);
console.log(a.toFixed(2)); // "12345.68"
console.log(a.toExponential(2)); // "1.23e+4"
console.log(a.toPrecision(6)); // "12345.7"

以上即是 bignumber.js 库中的一些常用方法。通过这种库,你可以在 JavaScript 中进行高精度的大数字运算,避免因为浮点数精度问题而导致的运算错误。

相关文章:

bignumber.js库,解决前端小数精度问题

bignumber.js 是一个 JavaScript 库,用于执行任意精度的十进制运算,特别适合处理大数字和需要高精度运算的情况。以下是一些 bignumber.js 库中的常用方法及其简要解释: 初始化 首先,你需要安装 bignumber.js 库: n…...

Java爬虫安全策略:防止TikTok音频抓取过程中的请求被拦截

摘要 在当今互联网时代,数据采集已成为获取信息的重要手段。然而,随着反爬虫技术的不断进步,爬虫开发者面临着越来越多的挑战。本文将探讨Java爬虫在抓取TikTok音频时的安全策略,包括如何防止请求被拦截,以及如何提高…...

通过手机控制家用电器的一个程序的设计(一)

一、概述 设计一款安卓平台上的家庭智能控制软件,通过语音识别指令控制家用电器。该软件结合离线语音识别技术、红外线和WIFI通讯技术,实现对家电的智能控制,如开关机、调温度、调频道等操作。 二、主要功能模块 离线语音识别模块 功能&…...

批量提取PDF指定区域内容到 Excel , 根据PDF文件第一行文字来自动重命名v1.3-附思路和代码实现

本次文章更新内容,图片以及扫描的PDF也可以支持批量提取指定区域内容了,主要是通过截图指定区域,然后使用OCR来识别该区域的文字来实现的,所以精度可能会有点不够,但是如果是数字的话,问题不大;…...

【持续集成_05课_Linux部署SonarQube及结合开发项目部署】

一、Linux下安装SonarQube 1、安装sonarQube 前置条件:sonarQube不能使用root账号进行启动,所以需要创建普通用户及 其用户组 1)创建组 2)添加用户、组名、密码 3)CMD上传qube文件-不能传到home路径下哦 4&#xff09…...

人像视频预处理【时间裁剪+画面裁切+调整帧率】

在视频处理中,cut(裁剪)、crop(画面裁切)和fps(帧率调整)这三个操作的顺序安排对最终的视频质量和效率有重要影响。以下是一种推荐的顺序和理由,旨在提高效率和减少错误:…...

SpringBoot+HttpClient实现文件上传下载

服务端:SpringBoot Controller package com.liliwei.controller;import java.io.File; import java.io.FileInputStream; import java.io.IOException;import javax.servlet.http.HttpServletResponse;import org.springframework.http.HttpHeaders; import org.s…...

QT--控件篇四

一、对话框 在软件开发中,对话框(Dialog)是一种常见的用户界面元素,用于与用户进行交互和获取信息。它通常以模态或非模态的形式出现,模态对话框会阻止用户与应用程序的其他部分交互,直到对话框关闭为止&a…...

opencv—常用函数学习_“干货“_2

目录 五、矩阵计算函数 归一化矩阵 (normalize) 转置矩阵 (transpose) 求矩阵的逆 (invert) 翻转矩阵 (flip) 旋转矩阵 (rotate) 求矩阵的行列式 (determinant) 求矩阵的迹 (trace) 求矩阵的特征值和特征向量 (eigen) 六、代数运算 矩阵加法 (add) 矩阵减法 (subtra…...

解析CSS与JavaScript的使用方法及ECMAScript语法规则

一、CSS的三种使用方式 CSS&#xff08;层叠样式表&#xff09;用于定义网页的样式和布局。以下是CSS的三种使用方式&#xff1a; 1. 内联样式 内联样式是最直接的应用方式&#xff0c;它通过HTML标签的style属性来定义。 代码示例&#xff1a; <h1 style"color: …...

从零开始学习嵌入式----结构体struct和union习题回顾

一、通过结构体和自定义函数实现成绩从大到小的排序&#xff0c;要求在主函数内定义结构体数组。 #include <stdio.h> //定义一个结构体类型 typedef struct Student {int age;char name[32];float score; } STU; //定义一个函数实现成绩从小到大的排序 void fun(STU *p…...

建筑产业网元宇宙的探索与实践

在数字化浪潮的推动下&#xff0c;建筑产业网正迈入一个全新的元宇宙时代。这一变革不仅为建筑设计、施工与管理带来了革新&#xff0c;也为整个行业注入了新的活力与创造力。本文将深入探讨建筑产业网元宇宙的特点、应用及未来趋势&#xff0c;带您领略其在建筑行业中的独特魅…...

比较RMI、HTTP+JSON/XML、gRPC

RMI&#xff08;Remote Method Invocation&#xff0c;远程方法调用&#xff09;、HTTPJSON/XML、gRPC是三种不同的技术或协议&#xff0c;它们各自在远程通信、数据传输和服务交互方面有不同的特点和应用场景。以下是对这三种技术的详细比较&#xff1a; 1. RMI&#xff08;R…...

软件工程-可行性分析

一、可行性分析 可行性分析/研究目的是用最小的代价在尽可能短的时间内确定问题是否得到解决。 FVPV&#xff08;1r&#xff09;^n* FV&#xff1a;未来价值 PV&#xff1a;现值&#xff08;当前货币金额&#xff09; r&#xff1a;利率 n&#xff1a;时间期限 纯收入累计的现…...

iOS ------ 消息传递和消息转发

一&#xff0c;消息传递 在OC中&#xff0c;传递消息就是在对象上调用方法。 相对于C语言的方法就“静态绑定”的函数&#xff0c;在编译器就决定了运行时所要调用的函数。在OC中&#xff0c;如果向某对象传递消息&#xff0c;就会使用动态绑定机制来决定需要调用那个方法。调…...

计算机视觉之Vision Transformer图像分类

Vision Transformer&#xff08;ViT&#xff09;简介 自注意结构模型的发展&#xff0c;特别是Transformer模型的出现&#xff0c;极大推动了自然语言处理模型的发展。Transformers的计算效率和可扩展性使其能够训练具有超过100B参数的规模空前的模型。ViT是自然语言处理和计算…...

【深度学习】BeautyGAN: 美妆,化妆,人脸美妆

https://www.sysu-hcp.net/userfiles/files/2021/03/01/3327b564380f20c9.pdf 【深度学习】BeautyGAN: Instance-level Facial Makeup Transfer with Deep Generative Adversarial Network BeautyGAN: Instance-level Facial Makeup Transfer with Deep Generative Adversaria…...

RocketMQ~架构与工作流程了解

简介 RocketMQ 具有高性能、高可靠、高实时、分布式 的特点。它是一个采用 Java 语言开发的分布式的消息系统&#xff0c;由阿里巴巴团队开发&#xff0c;在 2016 年底贡献给 Apache&#xff0c;成为了 Apache 的一个顶级项目。 在阿里内部&#xff0c;RocketMQ 很好地服务了集…...

学习Python的IDE功能--(一)入门导览

项目视图是主要工具窗口之一。它包含项目目录、SDK 特定的外部库和临时文件。点击带条纹的按钮可以预览演示项目。您也可以按Alt1打开。点击以打开项目视图&#xff0c;展开项目目录以查看项目文件。双击以打开welcome.py。 切换到"学习"工具窗口继续学习本课次。…...

gdb调试多线程程序

目录 1、pstack查看各个线程的调用堆栈2、gdb调试多线程2.1 查看线程信息2.2 切换线程2.3 进入线程某层具体的调用堆栈2.4 调度器锁2.4.1 查看调度器锁模式 3、实战3.1 调试多线程崩溃3.2 调试多线程死锁 1、pstack查看各个线程的调用堆栈 命令&#xff1a; 1、查看进程id ps …...

2026局放仪选型与避坑:谁家局放仪更具性价比?

在高压配电网与智能电网的运维体系中&#xff0c;局部放电&#xff08;Partial Discharge, PD&#xff09;检测已成为保障电力资产安全、避免非计划停电的关键环节。根据《高压开关柜局部放电诊断定位技术研究与运用》的统计数据&#xff0c;在开关柜的各类故障中&#xff0c;绝…...

[特殊字符]️ 信创服务器深度解析:从CPU到操作系统,一文搞懂国产化替代全栈方案

标签&#xff1a;信创 国产化 服务器 CPU选型 海光 鲲鹏 &#x1f3af; 开篇导读 你是否在国产化替代项目中不知道选哪款CPU&#xff1f;网上搜到的信创资料要么只讲政策不讲技术&#xff0c;要么直接给产品列表却不解释选型逻辑。本文将从信创服务器的四层架构&#xff08;硬…...

Gofile高效下载命令行工具完全指南:解锁批量下载与断点续传的终极解决方案

Gofile高效下载命令行工具完全指南&#xff1a;解锁批量下载与断点续传的终极解决方案 【免费下载链接】gofile-downloader Download files from https://gofile.io 项目地址: https://gitcode.com/gh_mirrors/go/gofile-downloader 在当今数字资源共享的时代&#xff0…...

ComfyUI Manager插件架构优化:5种高效部署方案与性能调优指南

ComfyUI Manager插件架构优化&#xff1a;5种高效部署方案与性能调优指南 【免费下载链接】ComfyUI-Manager ComfyUI-Manager is an extension designed to enhance the usability of ComfyUI. It offers management functions to install, remove, disable, and enable variou…...

数字体育可视化 | 智慧赛事与场馆全域协同管控

在发展新质生产力的时代背景下&#xff0c;我国智慧体育行业迎来全新发展机遇与时代使命&#xff0c;进入高速蓬勃发展的新阶段。作为智慧体育生态的核心单元&#xff0c;数字体育通过新一代信息技术与体育产业的深度融合&#xff0c;覆盖群众体育、竞技体育、赛事运营、体育产…...

如何永久免费解锁Cursor Pro全部功能:终极解决方案完全指南

如何永久免费解锁Cursor Pro全部功能&#xff1a;终极解决方案完全指南 【免费下载链接】cursor-free-vip [Support 0.45]&#xff08;Multi Language 多语言&#xff09;自动注册 Cursor Ai &#xff0c;自动重置机器ID &#xff0c; 免费升级使用Pro 功能: Youve reached you…...

SAP MIRO发票校验时,如何用增强LMR1M001自动检查供应商号?

SAP MIRO发票校验中供应商号自动检查的增强实战指南 在SAP系统中&#xff0c;发票校验(MIRO)是财务流程中的关键环节&#xff0c;而供应商号的准确性直接关系到后续的付款和账务处理。想象一下这样的场景&#xff1a;采购部门创建了一个采购订单&#xff0c;但财务人员在录入发…...

别再手动拖拽了!Unity运行时动态生成材质球,实现AR涂鸦功能的完整流程(附代码)

Unity运行时动态材质生成&#xff1a;打造高性能AR涂鸦系统的核心技术解析 在移动AR应用开发中&#xff0c;实时材质生成技术正成为提升用户体验的关键突破点。想象这样一个场景&#xff1a;儿童教育应用中&#xff0c;孩子随手绘制的涂鸦瞬间变成3D恐龙皮肤的纹理&#xff1b;…...

手把手教你用SPI配置AD9253寄存器:从芯片手册到FPGA驱动的完整避坑指南

手把手教你用SPI配置AD9253寄存器&#xff1a;从芯片手册到FPGA驱动的完整避坑指南 当第一次拿到AD9253这款四通道14位高速ADC芯片时&#xff0c;许多工程师会被其丰富的功能和复杂的寄存器配置所困扰。本文将从一个实战工程师的角度&#xff0c;带你一步步完成从SPI配置到FPGA…...

告别HDR格式混乱:用Python代码实战HLG与PQ曲线互转(附完整代码)

告别HDR格式混乱&#xff1a;用Python代码实战HLG与PQ曲线互转&#xff08;附完整代码&#xff09; 在视频处理领域&#xff0c;HDR&#xff08;高动态范围&#xff09;技术已经成为提升视觉体验的关键要素。然而&#xff0c;HLG&#xff08;Hybrid Log-Gamma&#xff09;和PQ&…...