登录
首页 >  文章 >  前端

JavaScriptIntl对象支持哪些本地化功能

时间:2026-01-10 13:51:38 420浏览 收藏

本篇文章给大家分享《JavaScript Intl 对象能处理哪些本地化任务》,覆盖了文章的常见基础知识,其实一个语言的全部知识点一篇文章是不可能说完的,但希望通过这些问题,让读者对自己的掌握程度有一定的认识(B 数),从而弥补自己的不足,更好的掌握它。

Intl 是 JavaScript 内置国际化 API,支持日期、数字、货币、列表、相对时间和字符串排序的本地化格式化;需传入语言标签如 "zh-CN" 创建实例,不处理文本翻译。

如何实现javascript国际化_Intl对象能处理哪些本地化任务

Intl 对象是 JavaScript 内置的国际化 API,专为多语言、多地区适配设计,无需第三方库就能处理日期、数字、货币、时间、排序和相对时间等本地化任务。

支持的核心本地化任务

Intl 提供多个构造函数,各自专注一类格式化需求:

  • Intl.DateTimeFormat:按地区习惯格式化日期和时间(如 “2024年6月12日” vs “Jun 12, 2024” vs “12.06.2024”)
  • Intl.NumberFormat:处理数字分组(千位符)、小数位数、百分比、科学计数法,还支持货币符号位置、币种代码(如 ¥1,234.56 vs $1,234.56 vs 1.234,56 €)
  • Intl.ListFormat:按语言规则连接列表项(如 English: “a, b, and c”;Chinese: “a、b和c”;Japanese: “a、b、c”)
  • Intl.RelativeTimeFormat:将时间差转为自然语言(如 “in 2 days” / “2天后” / “2日後”)
  • Intl.Collator:实现符合语言习惯的字符串比较与排序(例如德语中 “ä” 排在 “a” 之后,中文按拼音或笔画排序)

基本用法:指定语言和地区标签

所有 Intl 构造函数都接受两个参数:首选语言标签(如 "zh-CN""en-US""ja-JP")和可选配置对象。浏览器会自动回退到更通用的区域设置(如未找到 "zh-HK",可能降级为 "zh")。

示例:格式化人民币价格

const formatter = new Intl.NumberFormat("zh-CN", {
  style: "currency",
  currency: "CNY"
});
formatter.format(1234.56); // → "¥1,234.56"

动态切换与浏览器语言检测

可通过 navigator.languagenavigator.languages 获取用户系统偏好,再传给 Intl 构造函数。注意它返回的是浏览器语言设置,不是用户手动选择的语言,生产环境建议配合后端语言配置或用户设置使用。

常见做法:

  • 初始化时读取 navigator.language 作为默认值
  • 提供语言切换 UI,并将选中值存入 localStorage 或 URL 参数
  • 每次格式化前,用当前有效语言标签创建新 Intl 实例(Intl 对象不可复用不同 locale)

注意事项与兼容性

Intl 在现代浏览器中支持良好(Chrome 24+、Firefox 29+、Safari 10+、Edge 12+),但 IE 完全不支持。如需兼容旧版 IE,必须引入 polyfill(如 @formatjs/intl-numberformat@formatjs/intl-datetimeformat)。

另外,Intl 不处理翻译文本内容(比如按钮文字、提示语),它只负责“如何显示”——日期怎么排、数字怎么分隔、列表怎么连词。文本翻译需配合 i18n 框架(如 i18next、vue-i18n)或自定义资源包实现。

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《JavaScriptIntl对象支持哪些本地化功能》文章吧,也可关注golang学习网公众号了解相关技术文章。

前往漫画官网入口并下载 ➜
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>