使用您最喜欢的AI助手总结文档,并引用此页面和AI提供商
此文档已过期,基础版本已在以下日期更新 2026年1月20日.
前往英文文档版本历史
- "添加了 vue 格式化器"v5.8.02025/8/20
- "添加了格式化器文档"v5.8.02025/8/18
- "添加列表格式化器文档"v5.8.02025/8/20
- "添加额外的 Intl 工具(DisplayNames、Collator、PluralRules)"v5.8.02025/8/20
- "添加语言环境工具(getLocaleName、getLocaleLang、getLocaleFromPath 等)"v5.8.02025/8/20
- "添加内容处理工具(getContent、getTranslation、getIntlayer 等)"v5.8.02025/8/20
此页面的内容已使用 AI 翻译。
查看英文原文的最新版本如果您有改善此文档的想法,请随时通过在GitHub上提交拉取请求来贡献。
文档的 GitHub 链接复制文档 Markdown 到剪贴板
Intlayer 格式化工具
概述
Intlayer 提供了一组基于原生 Intl API 构建的轻量级辅助工具,以及一个缓存的 Intl 包装器,避免重复构建重量级的格式化器。这些工具完全支持本地化,可以直接从主 intlayer 包中使用。
导入
如果您使用 React,也可以使用 hooks;请参见 react-intlayer/format。
缓存的 Intl
导出的 Intl 是对全局 Intl 的一个轻量级缓存包装器。它会缓存 NumberFormat、DateTimeFormat、RelativeTimeFormat、ListFormat、DisplayNames、Collator 和 PluralRules 的实例,从而避免重复构建相同的格式化器。
由于格式化器的构建相对昂贵,这种缓存机制在不改变行为的情况下提升了性能。该包装器暴露了与原生 Intl 相同的 API,因此用法完全一致。
- 缓存是按进程进行的,对调用者透明。
如果环境中不支持 Intl.DisplayNames,则只会打印一次仅限开发者的警告(建议使用 polyfill)。
示例:
额外的 Intl 工具
除了格式化辅助工具外,您还可以直接使用缓存的 Intl 包装器来使用其他 Intl 功能:
Intl.DisplayNames
用于获取语言、地区、货币和书写系统的本地化名称:
Intl.Collator
用于基于区域设置的字符串比较和排序:
Intl.PluralRules
用于确定不同区域设置中的复数形式:
区域设置工具
getLocaleName(displayLocale, targetLocale?)
获取某个区域设置在另一种区域设置中的本地化名称:
- displayLocale: 要获取名称的语言环境
- targetLocale: 用于显示名称的语言环境(默认为 displayLocale)
getLocaleLang(locale?)
从语言环境字符串中提取语言代码:
- locale: 要提取语言代码的语言环境(默认为当前语言环境)
getLocaleFromPath(inputUrl)
从 URL 或路径名中提取语言环境段:
- inputUrl:要处理的完整 URL 字符串或路径名
- returns:检测到的语言环境,如果未找到语言环境则返回默认语言环境
getPathWithoutLocale(inputUrl, locales?)
从 URL 或路径名中移除语言环境段:
- inputUrl:要处理的完整 URL 字符串或路径名
- locales:可选的支持语言数组(默认为配置的语言)
- returns:去除语言段后的 URL
getLocalizedUrl(url, currentLocale, locales?, defaultLocale?, prefixDefault?)
为当前语言生成本地化 URL:
- url:要本地化的原始 URL
- currentLocale:当前语言
- locales:可选的支持语言数组(默认为配置的语言)
- defaultLocale:可选的默认语言环境(默认为配置的默认语言环境)
- prefixDefault:是否为默认语言环境添加前缀(默认为配置值)
getHTMLTextDir(locale?)
返回指定语言环境的文本方向:
- locale:要获取文本方向的语言环境(默认为当前语言环境)
- returns:返回
"ltr"、"rtl"或"auto"
内容处理工具
getContent(node, nodeProps, locale?)
使用所有可用插件(翻译、枚举、插入等)转换内容节点:
- node:要转换的内容节点
- nodeProps:转换上下文的属性
- locale:可选的语言环境(默认为配置的默认语言环境)
getTranslation(languageContent, locale?, fallback?)
从语言内容对象中提取特定语言环境的内容:
- languageContent:映射语言环境到内容的对象
- locale:目标语言环境(默认为配置的默认语言环境)
- fallback:是否回退到默认语言环境(默认为 true)
getIntlayer(dictionaryKey, locale?, plugins?)
通过键检索并转换字典中的内容:
- dictionaryKey:要检索的字典键
- locale:可选的语言环境(默认为配置的默认语言环境)
- plugins:可选的自定义转换插件数组
getIntlayerAsync(dictionaryKey, locale?, plugins?)
异步从远程字典中检索内容:
- dictionaryKey:要检索的字典键
- locale:可选的语言环境(默认为配置的默认语言环境)
- plugins:可选的自定义转换插件数组
格式化工具
以下所有辅助函数均从 intlayer 导出。
number(value, options?)
使用基于区域设置的分组和小数格式化数字值。
- value:
number | string - options:
Intl.NumberFormatOptions & { locale?: LocalesValues }
示例:
percentage(value, options?)
将数字格式化为百分比字符串。
行为:大于 1 的值被解释为完整的百分比并进行归一化(例如,25 → 25%,0.25 → 25%)。
- value:
number | string - options:
Intl.NumberFormatOptions & { locale?: LocalesValues }
示例:
currency(value, options?)
将数值格式化为本地化货币。默认使用 USD,保留两位小数。
- value:
number | string - options:
Intl.NumberFormatOptions & { locale?: LocalesValues }- 常用字段:
currency(例如"EUR"),currencyDisplay("symbol" | "code" | "name")
- 常用字段:
示例:
date(date, optionsOrPreset?)
使用 Intl.DateTimeFormat 格式化日期/时间值。
- date:
Date | string | number - optionsOrPreset:
Intl.DateTimeFormatOptions & { locale?: LocalesValues }或者以下预设之一:- 预设值:
"short" | "long" | "dateOnly" | "timeOnly" | "full"
- 预设值:
示例:
relativeTime(from, to = new Date(), options?)
使用 Intl.RelativeTimeFormat 格式化两个时间点之间的相对时间。
- 传入 "now" 作为第一个参数,目标时间作为第二个参数,可以获得自然的表达方式。
- from:
Date | string | number - to:
Date | string | number(默认为new Date()) - options:
{ locale?: LocalesValues; unit?: Intl.RelativeTimeFormatUnit; numeric?: Intl.RelativeTimeFormatNumeric; style?: Intl.RelativeTimeFormatStyle }- 默认
unit为"second"。
- 默认
示例:
units(value, options?)
使用 Intl.NumberFormat 的 style: 'unit' 将数值格式化为本地化的单位字符串。
- value:
number | string - options:
Intl.NumberFormatOptions & { locale?: LocalesValues }- 常用字段:
unit(例如"kilometer","byte"),unitDisplay("short" | "narrow" | "long") - 默认值:
unit: 'day',unitDisplay: 'short',useGrouping: false
- 常用字段:
示例:
compact(value, options?)
使用紧凑表示法格式化数字(例如,1.2K,1M)。
- value:
number | string - options:
Intl.NumberFormatOptions & { locale?: LocalesValues }(内部使用notation: 'compact')
示例:
list(values, options?)
使用 Intl.ListFormat 将值数组格式化为本地化的列表字符串。
- values:
(string | number)[] - options:
Intl.ListFormatOptions & { locale?: LocalesValues }- 常用字段:
type("conjunction" | "disjunction" | "unit"),style("long" | "short" | "narrow") - 默认值:
type: 'conjunction',style: 'long'
- 常用字段:
示例:
说明
- 所有辅助函数都接受
string类型的输入;它们会在内部被强制转换为数字或日期。 - 如果未提供,区域设置默认使用您配置的
internationalization.defaultLocale。 - 这些工具是轻量封装;对于高级格式化,请直接传递标准的
Intl选项。
入口点和重新导出(@index.ts)
格式化函数位于核心包中,并从更高级的包中重新导出,以保持跨运行时的导入简洁:
示例:
React
客户端组件:
服务器组件(或 React 服务器运行时):
这些钩子将会从IntlayerProvider或IntlayerServerProvider中获取语言环境
Vue
客户端组件:
这些组合式函数将会使用注入的 IntlayerProvider 中的语言环境