如何在 JavaScript 中将数字格式化为美元货币字符串?


本教程将教你如何在 JavaScript 中将数字格式化为美元货币字符串。现在,问题来了,为什么我们需要将数字格式化为美元货币字符串?答案在这里。用户可以考虑这样的场景:他们正在开发一个电子商务网站或应用程序,并且必须向客户显示产品价格。如果他们将产品价格显示为2500$2500会怎么样?第二个看起来更好,因为‘$’代表USD货币,是显示USD货币的标准化方式。此外,第二种方法更容易理解。

下面,我们提供了解决上述问题并将数字显示为 USD 货币字符串的不同方法。

  • 使用字符串连接
  • 使用Intl.NumberFormat()方法
  • 使用toLocaleString()方法

使用字符串连接

在这种方法中,我们将简单地使用 JavaScript 中的‘+’符号进行字符串连接。这是将数字表示为美元货币字符串最简单的方法。

语法

let price = 1642;
var currencyUSD = ‘$’ + price;

示例 1

下面的示例演示了用户如何使用 JavaScript 中的字符串连接在数字前添加 ‘$’ 符号。

<!DOCTYPE html>
<html>
<body>
   <h2>Format Numbers as a dollar currency string</h2>
   <p> Formatting 1642 as US dollars (US$):</p>
   <p id="result"> </p>
   <script type="text/javascript">
      // function to format number with $ sign.
      function formatNumberWithDollar() {
         let price = 1642;
         let formattedPrice = '$' + price;
         var result = document.getElementById("result");
         result.innerHTML = formattedPrice ;
      }
      formatNumberWithDollar();
   </script>
</body>
</html>

在上面的输出中,用户可以看到我们的价格是如何用美元货币符号字符串格式化的。

使用Intl.NumberFormat()方法

在 JavaScript 中,将数字格式化为货币字符串的最佳方法之一是使用Intl.NumberFormat()方法。您可以将区域设置作为参数传递给该方法,并在数字前设置美元符号并格式化数字。

你们中有些人第一次听说区域设置这个词。它不是 JavaScript 中的任何方法,但它根据本地区域提供了一组参数。简单来说,它指定了区域编号格式、日期和时间格式、货币格式、星期几格式等。

语法

let formatting_options = {
   style: 'currency',
   currency: 'USD',
   minimumFractionDigits: 3,
}
let dollarString = new Intl.NumberFormat( locale_string, formatting_options );

参数

  • locale_string  − 它应该根据您想要获取本地参数的区域进行传递。例如,要获取美国的本地参数,您将传递 ‘en-US’,对于印度,您将传递 ‘en-IN’。

  • formatting_options − 它是一个包含许多用于格式化数字字符串的属性的对象。主要的是,下面的三个选项属性更有价值。

  • style − 它是数字格式化字符串的基本样式。它采用三个不同的值,例如“currency”、“decimal”和“percentage”。在本例中,我们将使用“currency”。

  • currency − 此参数指定货币符号,例如美元的“USD”。

  • minimumFractionDigits − 使用此参数,我们可以四舍五入小数点后的数字位数。

示例 2

下面的示例演示了 Intl.NumberFormatting() 方法的使用。

<!DOCTYPE html>
<html >
<head>
<body>
   <h2> The Intl.NumberFormat() method</h2>
   <p> Formatting 5323.35445 as US dollars (US$):</p>
   <p id="result"></p>
   <p> We set minimumFractionDigits to 3.</p>
   <script type="text/javascript">
      // function to format number with Intl.NumberFormat() method.
      function formatNumberWithDollar() {
         let formatting_options = {
            style: 'currency',
            currency: 'USD',
            minimumFractionDigits: 3,
         }
         // users can see how locale passed as a parameter.
         let dollarString = new Intl.NumberFormat("en-US", formatting_options);
         let finalString = dollarString.format(5323.35445);
         var result = document.getElementById("result");
         result.innerHTML = finalString;
      }
      formatNumberWithDollar();
   </script>
</body>
</html>

在上面的输出中,用户可以看到数字被四舍五入到 3 位,并以带有美元符号的字符串形式表示。

使用toLocaleString()方法

toLocaleString()也是 JavaScript 中的内置方法,与 Intl.numberFormat() 方法类似。它采用与 Intl.numberFormat 方法相同的参数,并将字符串转换为特定于区域的字符串。

语法

let formatting_options = {
   style: ‘currency’,
   currency: ‘USD’,
   minimumFractionDigits: 3,
}
let dollarString = toLocaleString( locale_string, formatting_options );

参数

它采用与Intl.numberFormat()方法相同的参数。用户可以参考上述方法。

示例 3

下面的示例演示了使用toLocaleString()方法用美元符号格式化数字。

<!DOCTYPE html>
<html >
<head>
<body>
   <h2> The toLocaleString() method</h2>
   <p> Formatting 2434454.6554 as US dollars (US$):</p>
   <p id="result"></p>
   <script type="text/javascript">
      let formatting_options = {
         style: 'currency',
         currency: 'USD',
         minimumFractionDigits: 3,
      }
      let price = 2434454.6554;
      let numberWithDollar = price.toLocaleString("en-US",
      formatting_options);
      var result = document.getElementById("result");
      result.innerHTML = numberWithDollar;
   </script>
</body>
</html>

上述方法给出的输出与Intl.numberFormat()方法相同。在上述结果中,用户可以看到数字是用美元符号格式化的,并且小数点后四舍五入到 3 位。

结论

本教程介绍了三种不同的方法来使用美元字符串格式化数字。解决我们问题的最佳和标准方法是第二种方法。使用Intl.numberFormat()方法,您可以将所有字符串、数字和参数转换为区域敏感的字符串。

更新于:2022年7月12日

15K+ 次查看

启动您的 职业生涯

通过完成课程获得认证

开始
广告