JavaScriptIntl对象支持哪些本地化功能
时间:2026-01-10 13:51:38 420浏览 收藏
本篇文章给大家分享《JavaScript Intl 对象能处理哪些本地化任务》,覆盖了文章的常见基础知识,其实一个语言的全部知识点一篇文章是不可能说完的,但希望通过这些问题,让读者对自己的掌握程度有一定的认识(B 数),从而弥补自己的不足,更好的掌握它。
Intl 是 JavaScript 内置国际化 API,支持日期、数字、货币、列表、相对时间和字符串排序的本地化格式化;需传入语言标签如 "zh-CN" 创建实例,不处理文本翻译。

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.language 或 navigator.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学习网公众号了解相关技术文章。
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
425 收藏
-
307 收藏
-
161 收藏
-
198 收藏
-
461 收藏
-
271 收藏
-
386 收藏
-
336 收藏
-
487 收藏
-
106 收藏
-
453 收藏
-
311 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习