iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >如何处理JavaScript 中的货币值?
  • 874
分享到

如何处理JavaScript 中的货币值?

2023-06-03 13:06:14 874人浏览 独家记忆
摘要

金钱无处不在。       无论在银行应用程序、电子商务网站还是证券交易所平台,我们每天都在与金钱互动。我们也越来越依赖技术来处理问题。       然而,关于

金钱无处不在。

       无论在银行应用程序、电子商务网站还是证券交易所平台,我们每天都在与金钱互动。我们也越来越依赖技术来处理问题。

       然而,关于如何以编程处理货币价值尚无共识。虽然金钱是现代社会中普遍存在的概念,但相较于日期和时间之类的东西,它并不是任何主流语言中的一流数据类型。结果,每一种软件都有自己的处理方式,且伴随着陷阱。

陷阱#1:金钱是数字?

       当你需要代表钱时,你的第一直觉可能是使用一个数字。

       金钱只不过是一个数值,对吧?

       错了。

       货币价值的一部分与另一对象有关:货币。没有10“钱”,应该是“10美元,10欧元,10比特币”......如果你想用不同的货币添加两个货币值,你需要先转换它们。如果你想比较它们也是如此:如果你只有一个金额,你就无法进行准确的比较。金额和货币谁也离不开谁。

陷阱#2:让人烦恼的小数点

       大多数现代货币额都是以小数形式出现,或根本没有子单位。这意味着当货币有子单位时,主单位中这些单位的数量是10的幂。例如,一美元有100美分——10的2次幂。

       使用十进制系统具有优势,但在编程方面有一个问题。计算机使用二进制系统,因此它们不能原生地表示十进制数。有些语言提出了自己的解决方案,如Java中的BigDecimal类型或C#中的小数类型。javascript只有Number类型,可以用作整数或双精度浮点数。因为它是基础10系统的二进制表示,所以当你尝试进行数学运算时,最终会得到不准确的结果。

       使用浮点来存储货币价值是一个坏主意。

       当你计算更多值时,难以察觉的精度误差会导致更大的差异。这不可避免地导致最终的四舍五入问题。 

陷阱#3:百分比与分期

       有时你需要计算分期,但百分比总是或增加或减少付款数。

       想象一下,你需要支付999.99美元,首付50%。这可以通过一些简单的数学来完成。一半是499.995美元,但是你不能再分一分钱,所以你可能会把结果分成500美元。问题是,当你付尾款时,你最终会获得相同的结果并且额外付一分钱。

       分期有时候会遇到除不尽的情况。天然气价格可能显示超过两位数,但它只是象征性的:你最终总是支付一个四舍五入的价格。

编程人员应该怎么办?

       幸运的是,软件工程师Martin Fowler提出了一个解决方案。在企业应用程序架构模式中,他描述了货币价值的模式:

属性

方法

数学:加,减,乘,除

比较:等于,大于,大于或等于,小于,小于或等于。

       由此,你可以创建满足大部分货币需求的价值对象。

“金额+货币”作为数据结构

       金钱的行为与简单的数字不同,因此应区别对待。第一个也是最重要的是:它应该始终由金额和货币组成。

       你可以将货币金额一起添加,检查它们的值是否相对应,并将它们格式化为你需要的任何内容。这可以通过对象的方法完成。在JavaScript中,任何返回对象的函数都可以解决问题。

以美分计额

       有几种方法可以解决JavaScript中的浮点问题。

       你可以使用像Decimal.js这样的库来将浮点数作为字符串。这不是一个糟糕的解决方案,当你必须处理大数字时,它会派上用场。然而,它以增重依赖性为代价,导致性能降低。

       你可以在计算之前将浮点数乘以整数,然后将它们分开。

如何处理JavaScript 中的货币值?

       这是一个很好的解决方案,但需要在对象构造或每次操作时进行额外的计算。这不一定会影响性能,但仍然需要更多的流程工作。

       第三种方法是直接以美分为单位存储相对于单位的值。如果你需要存储10美分,则不会存储0.1,而是10.这允许你仅使用整数,这意味着安全计算(直到你遇到大数字)和出色的性能。

        如何处理JavaScript 中的货币值

       Dinero.js:一个用于创建、计算和格式化货币价值的不可变库

       从以上观察中,我创建了一个JavaScript库:Dinero.js。

如何处理JavaScript 中的货币值?

       Dinero.js遵循Fowler的模式更多一点儿。它允许你在JavaScript中创建、计算和格式化货币值。你可以进行数学运算、解析和格式化对象,甚至向他们提问,使你的开发过程更加轻松。

       该库设计为不可变和可链接的模式。它支持全局设置,具有扩展格式选项,并提供本机国际化支持。

为什么不可变?

       不可变库更安全,更好预测。可变操作和引用副本是许多错误的来源。选择不变性能够避免了这些错误。

       使用Dinero.js,你可以执行计算而无需担心更改原始用例。在以下vue.js示例中,调用priceWithTax时不会更改Price。如果用例是可变的,它将会更改价格。

如何处理JavaScript 中的货币值?

可链接性

       优秀的开发人员努力使他们的代码更简洁,更易于阅读。当你想要在单个对象上连续执行多个操作时,链接提供了优雅的符号和简洁的语法。

如何处理JavaScript 中的货币值?

全球设置

       当你处理大量货币价值时,你可能希望其中一些人分享一些属性。如果你使用德语制作网站,你可能希望以德国货币格式显示金额。

       这是全球设置派上用场的地方。你可以声明将应用于所有新对象的选项,而不是将它们传递给每个用例。

如何处理JavaScript 中的货币值?

原生国际化支持

       传统意义上,库使用区域设置文件进行国际化。

如何处理JavaScript 中的货币值?

       区域设置文件也很难维护。Internationalization api是原生的,并且得到了很不错的支持。除非你必须使用过时的或不知名的浏览器,否则toFORMat可以安全使用。

格式化

       对象很适合存储数据,但在显示数据时却没那么有用。Dinero.js提供了各种格式化方法,包括toFormat。它为Number.prototype.toLocaleString提供了直观而简洁的语法。将它与setLocale配对,你将能够以任何语言将任何Dinero对象显示为正确的格式。这对多语言电子商务网站特别有用。

接下来做什么?

       大家广泛认同Fowler模式是一个不错的解决方案。它激发了许多语言的同步实现。如果你正在DIY,我推荐它和本文的观察结果作为起点。或者你可以选择Dinero.js:一种现代,可靠,经过全面测试的解决方案,已经可以使用。

        

        

--结束END--

本文标题: 如何处理JavaScript 中的货币值?

本文链接: https://www.lsjlt.com/news/234408.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何处理JavaScript 中的货币值?
    金钱无处不在。       无论在银行应用程序、电子商务网站还是证券交易所平台,我们每天都在与金钱互动。我们也越来越依赖技术来处理问题。       然而,关于...
    99+
    2023-06-03
  • JavaScript中值为undefined如何处理
    JavaScript中值为undefined如何处理,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。而在JavaScript里,当你要获取一个变...
    99+
    2024-04-02
  • 在 MySQL 数据库中存储货币值的最佳数据类型?
    为了表示金钱,我们需要使用 Decimal (TotalDigitsinteger, DigitsAfterDecimalinteger) 方法。 假设我们需要显示值 345.66。为此,计算有多少位可用。值345.66,一共有5位,小数点...
    99+
    2023-10-22
  • 如何在java中利用BigDecimal计算货币金额
    今天就跟大家聊聊有关如何在java中利用BigDecimal计算货币金额,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。float和double只能用来做科学计算或者是工程计算,在商业...
    99+
    2023-06-06
  • 如何将带有 $ 和 , 的货币列转换为数字
    问题内容 我在 pandas 数据框中有以下数据: 65贝德227d202 我想对三列(第一、第二、第三)执行一些简单的分析(例如 sum、groupby),但这三列的数据类型是对象(...
    99+
    2024-02-08
  • 如何处理MySQL中的NULL值
    在MySQL中,可以使用以下方法处理NULL值: 检查NULL值:使用IS NULL或IS NOT NULL操作符来检查NULL值...
    99+
    2024-04-09
    MySQL
  • MySQL中如何处理NULL值
    在MySQL中,可以使用以下方式处理NULL值: 使用IS NULL和IS NOT NULL操作符来判断NULL值: SELEC...
    99+
    2024-03-06
    MySQL
  • golang中如何处理空值?
    php小编鱼仔为您介绍golang中如何处理空值。在golang中,空值通常表示变量没有被赋值或者没有有效的值。为了处理空值,golang提供了多种方法。首先,可以使用条件语句(if语...
    99+
    2024-02-12
  • SQLite中如何处理空值
    在SQLite中处理空值的方式有以下几种: 使用NULL值:在SQLite中,NULL值表示缺失或未知的值。可以将NULL值存储...
    99+
    2024-04-09
    SQLite
  • Pandas如何处理DataFrame中的inf值
    目录如何处理DataFrame的inf值DataFrame有关inf的处理技巧什么是inf?为什么会产生?产生inf有什么好处?产生inf有什么坏处?怎么处理?怎么获取到inf的所在...
    99+
    2024-04-02
  • 如何在MySQL中设计一个可扩展的会计系统表结构以支持多种货币和汇率处理?
    如何在MySQL中设计一个可扩展的会计系统表结构以支持多种货币和汇率处理?随着全球经济的发展,越来越多的企业需要在其会计系统中处理多种货币和汇率。为了有效地支持这种需求,我们需要在数据库中设计一个可扩展的表结构。在MySQL中,我们可以通过...
    99+
    2023-10-31
    MySQL 表结构 会计系统
  • 如何在Hive中处理空值
    在Hive中处理空值通常有两种方法: 使用COALESCE函数:COALESCE函数可以将NULL值替换为指定的值。例如,如果要将...
    99+
    2024-04-02
  • 如何处理 Golang 中的 nil 错误值?
    非常抱歉,由于您没有提供文章标题,我无法为您生成一篇高质量的文章。请您提供文章标题,我将尽快为您生成一篇优质的文章。...
    99+
    2024-05-14
  • Keras中如何处理缺失值
    在Keras中处理缺失值的方法取决于数据集的特点以及建模的方式。以下列举了一些处理缺失值的常见方法: 将缺失值替换为固定值:可以将...
    99+
    2024-03-14
    Keras
  • 在Java中如何处理数组中的空值?
    在Java中,数组是一种常见的数据类型,它可以存储一组相同类型的数据。但是,在实际开发中,我们经常会遇到数组中存在空值的情况。这时,我们需要对数组中的空值进行处理,以确保程序的正确性和稳定性。 本文将介绍在Java中如何处理数组中的空值,包...
    99+
    2023-09-30
    数组 bash windows
  • 在SQL中该如何处理NULL值
    在日常使用数据库时,你在意过NULL值么? 其实,NULL值在数据库中是一个很特殊且有趣的存在,下面我们一起来看看吧; 小伙伴想精准查找自己想看的MySQL文章?喏 → M...
    99+
    2024-04-02
  • Kotlin语言中是如何处理null值的
    Kotlin语言中是如何处理null值的?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。Kotlin null的处理详解NullPointerException,...
    99+
    2023-05-31
    kotlin null
  • javascript中如何处理空格符
    今天小编给大家分享一下javascript中如何处理空格符的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。在JavaScrip...
    99+
    2023-07-06
  • PHP中如何安全地处理MySQL中的0值?
    PHP中如何安全地处理MySQL中的0值? 在PHP开发中,经常会涉及到与MySQL数据库进行交互并处理各种数据。在处理数据库中的0值时,我们需要注意一些安全性的问题,以避免出现意外的...
    99+
    2024-02-28
    mysql php 安全处理 防止sql注入
  • 如何理解JavaScript数值方法
    这篇文章将为大家详细讲解有关如何理解JavaScript数值方法,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。可以使用内置方法和属性对数字执行哪些有用的操作...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作