Is there a way to reverse the formatting by Intl.NumberFormat in JavaScript(有没有办法在 JavaScript 中通过 Intl.NumberFormat 反转格式)
问题描述
The Intl.NumberFormat
(see Mozilla's doc) provides a nice way in Javascript to format numbers into a current locale`s version like this:
new Intl.NumberFormat().format(3400); // returns "3.400" for German locale
But I couldn't find a way to reverse this formatting. Is there something like
new Intl.NumberFormat().unformat("3.400"); // returns 3400 for German locale
Thanks for any help.
I have found a workaround:
/**
* Parse a localized number to a float.
* @param {string} stringNumber - the localized number
* @param {string} locale - [optional] the locale that the number is represented in. Omit this parameter to use the current locale.
*/
function parseLocaleNumber(stringNumber, locale) {
var thousandSeparator = Intl.NumberFormat(locale).format(11111).replace(/p{Number}/gu, '');
var decimalSeparator = Intl.NumberFormat(locale).format(1.1).replace(/p{Number}/gu, '');
return parseFloat(stringNumber
.replace(new RegExp('\' + thousandSeparator, 'g'), '')
.replace(new RegExp('\' + decimalSeparator), '.')
);
}
Using it like this:
parseLocaleNumber('3.400,5', 'de');
parseLocaleNumber('3.400,5'); // or if you have German locale settings
// results in: 3400.5
Not the nicest solution but it works :-)
If anyone knows a better way of achieving this, feel free to post your answer.
Update
- Wrapped in a complete reusable function
- Using the regex class
p{Number}
to extract the separator. So that it also works with non-arabic digits. - Using number with 5 places to support languages where numbers are separated at every fourth digit.
这篇关于有没有办法在 JavaScript 中通过 Intl.NumberFormat 反转格式的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:有没有办法在 JavaScript 中通过 Intl.NumberFormat 反转


- 如何调试 CSS/Javascript 悬停问题 2022-01-01
- 使用 iframe URL 的 jQuery UI 对话框 2022-01-01
- 我不能使用 json 使用 react 向我的 web api 发出 Post 请求 2022-01-01
- 如何显示带有换行符的文本标签? 2022-01-01
- 从原点悬停时触发 translateY() 2022-01-01
- 是否可以将标志传递给 Gulp 以使其以不同的方式 2022-01-01
- 为什么我的页面无法在 Github 上加载? 2022-01-01
- 为什么悬停在委托事件处理程序中不起作用? 2022-01-01
- 如何向 ipc 渲染器发送添加回调 2022-01-01
- 在不使用循环的情况下查找数字数组中的一项 2022-01-01