登录
首页 >  文章 >  前端

JavaScript日期格式化与数字货币国际化方法

时间:2025-12-19 09:45:29 290浏览 收藏

推广推荐
免费电影APP ➜
支持 PC / 移动端,安全直达

从现在开始,努力学习吧!本文《JavaScript国际化API怎么用\_日期数字货币格式化方法》主要讲解了等等相关知识点,我会在golang学习网中持续更新相关的系列文章,欢迎大家关注并积极留言建议。下面就先一起来看一下本篇正文内容吧,希望能帮到你!

Intl API 是 JavaScript 原生国际化标准,提供 DateTimeFormat 和 NumberFormat 等接口,支持按 locale 自动格式化日期、时间、数字、货币等,推荐替代 toLocaleDateString 等不可靠旧方法。

javascript国际化API是什么_如何格式化日期、数字和货币?

JavaScript 国际化 API(Internationalization API,简称 Intl)是一套内置的、标准化的接口,用于在不同语言和区域环境下格式化日期、数字、货币、时间、相对时间、列表、消息等,无需依赖第三方库就能实现本地化显示。

Intl.DateTimeFormat:安全又灵活的日期/时间格式化

它根据用户所在地区自动适配星期顺序、月份名称、年月日顺序、12/24 小时制等。你只需指定 locale 和选项,浏览器就按当地习惯输出。

  • 基础用法:new Intl.DateTimeFormat('zh-CN').format(new Date())"2024年6月12日"
  • 带时间:new Intl.DateTimeFormat('en-US', { dateStyle: 'medium', timeStyle: 'short' }).format(new Date())"Jun 12, 2024, 3:45 PM"
  • 自定义组合:可用 yearmonthdayhourminute 等细粒度选项,比如 { year: 'numeric', month: 'long', day: 'numeric', weekday: 'long' }
  • 注意:不要用 toLocaleDateString() 等老方法做关键展示——它们行为不一致且不可靠;Intl 是唯一推荐方案

Intl.NumberFormat:统一处理数字、百分比与货币

它能按 locale 自动添加千分位分隔符、小数位数、负号位置、甚至本地化符号(如阿拉伯数字、印度分组方式),还能无缝支持货币单位。

  • 普通数字:new Intl.NumberFormat('de-DE').format(1234567.89)"1.234.567,89"
  • 百分比:new Intl.NumberFormat('ja-JP', { style: 'percent', minimumFractionDigits: 1 }).format(0.123)"12.3%"
  • 货币(关键!要指定 currency + currencyDisplay):new Intl.NumberFormat('zh-CN', { style: 'currency', currency: 'CNY', currencyDisplay: 'symbol' }).format(199.9)"¥199.90"
  • 注意:currency 必须是 ISO 4217 三字母代码(如 USD、EUR、CNY),且不是所有 locale 都默认支持所有货币;currencyDisplay: 'code' 可显示 "CNY",'narrowSymbol' 在某些 locale 下更简洁(如 ¥ 而非 CNY)

实际使用小贴士

  • locale 可传数组,例如 ['zh-CN', 'en-US'],浏览器会按顺序找第一个支持的
  • 避免硬编码格式字符串(如 "MM/DD/YYYY"),交给 Intl 推导最可靠
  • 服务端渲染时,若无法获取用户 locale,可先用 navigator.language 或 HTTP Accept-Language 头做 fallback
  • 格式化器可复用:创建一次实例,多次调用 .format(),性能更好

基本上就这些。Intl API 原生、稳定、覆盖主流需求,是现代前端做国际化格式化的事实标准。

到这里,我们也就讲完了《JavaScript日期格式化与数字货币国际化方法》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>