使用您最喜欢的AI助手总结文档,并引用此页面和AI提供商
版本历史
- "更新Solid useIntlayer API的用法以直接访问属性"v8.9.02026/5/4
- "发布稳定版"v8.0.02026/1/26
- "增加init命令"v8.0.02025/12/30
- "初始版本"v5.5.102025/6/29
此页面的内容已使用 AI 翻译。
查看英文原文的最新版本如果您有改善此文档的想法,请随时通过在GitHub上提交拉取请求来贡献。
文档的 GitHub 链接复制文档 Markdown 到剪贴板
使用Intlayer翻译您的Angular 21(Vite)网站 | 国际化 (i18n)
目录
为什么选择 Inlayer 而不是替代品?
与“ngx-translate”或“angular-l10n”等主要解决方案相比,Intlayer 是一个具有集成优化的解决方案,例如:
完整的角度覆盖
Intlayer 经过优化,可与 Angular 完美配合,提供组件级内容范围、延迟加载翻译以及扩展国际化 (i18n) 所需的所有功能。
捆绑尺寸
不要将大量 JSON 文件加载到页面中,而只需加载必要的内容。 Intlayer 有助于将捆绑包和页面大小减少多达 50%。
可维护性
确定应用程序内容的范围有利于大型应用程序的维护。您可以复制或删除单个功能文件夹,而无需承担检查整个内容代码库的精神负担。此外,Intlayer 具有完全类型化 (fully typed),以确保您的内容的准确性。
人工智能代理
共置内容减少大型语言模型 (LLM) 所需的上下文。 Intlayer 还附带了一套工具,例如用于测试缺失翻译的 CLI、LSP、MCP 和 agent技能,使 AI 代理的开发者体验 (DX) 更加流畅。
自动化
使用您选择的法学硕士,通过自动化在 CI/CD 管道中进行翻译,而费用由您的 AI 提供商承担。 Intlayer 还提供了一个编译器来自动提取内容,以及一个网络平台来帮助在后台翻译。
表现
将大量 JSON 文件连接到组件可能会导致性能和反应性问题。 Intlayer 可在构建时 (build time)优化您的内容加载。
无需开发即可扩展
Intlayer 不仅仅是一个 i18n 解决方案,还提供了一个自托管的可视化编辑器和一个完整的 CMS 来帮助您管理多语言内容实时,与译员、文案人员和其他团队成员无缝协作。内容可以本地和/或远程存储。
在Angular应用程序中设置Intlayer的分步指南
在GitHub上查看 应用程序模板。
配置您的项目
创建一个配置文件以配置您应用程序的语言:
intlayer.config.ts复制代码复制代码到剪贴板
import { Locales, type IntlayerConfig } from "intlayer"; const config: IntlayerConfig = { internationalization: { locales: [ Locales.ENGLISH, Locales.FRENCH, Locales.SPANISH, // 您支持的其他语言 ], defaultLocale: Locales.ENGLISH, }, }; export default config;通过此配置文件,您可以设置本地化的URL、中间件重定向、Cookie名称、内容声明的位置和扩展名、禁用控制台中的Intlayer日志等。获取所有可用参数的完整列表,请参考配置文档。
在Angular配置中集成Intlayer
要将Intlayer与Angular CLI集成,您需要使用自定义构建器。本指南假设您使用的是 Vite/esbuild(Angular 21项目的默认设置)。
首先,修改您的
angular.json,使用自定义的esbuild构建器。更新build和serve配置:angular.json复制代码复制代码到剪贴板
请确保将
angular.json中的your-app-name替换为您项目的实际名称。接下来,在项目的根目录中创建一个
esbuild.plugins.ts文件:esbuild.plugins.ts复制代码复制代码到剪贴板
intlayerEsbuildPlugin函数负责使用Intlayer配置esbuild。它注入插件来处理内容声明文件,并针对最佳性能进行了设置。NX 用户:NX 的 Angular 构建器通过 Node 的原生 ESM 解析加载插件文件,并且不会实时编译 TypeScript 插件文件。请改用
.mjs文件,并相应地更新angular.json中的plugins引用:esbuild.plugins.mjs复制代码复制代码到剪贴板
然后在
angular.json中指向"./esbuild.plugins.mjs",而不是"./esbuild.plugins.ts"。声明您的内容
创建并管理您的内容声明文件以存储翻译:
您的内容声明可以定义在应用程序的任何位置,只需将其包含在
contentDir目录(默认为./src)中,并且符合内容声明的文件后缀名(默认为.content.{json,ts,tsx,js,jsx,mjs,cjs,md,mdx,yaml,yml})。详细信息请参考 内容声明文档。
在代码中使用Intlayer
要在整个Angular应用程序中利用Intlayer的国际化功能,您需要在应用程序配置中提供Intlayer。
src/app/app.config.ts复制代码复制代码到剪贴板
然后,您可以在任何组件中使用
useIntlayer功能。src/app/app.component.ts复制代码复制代码到剪贴板
在您的模板中:
src/app/app.component.html复制代码复制代码到剪贴板
Intlayer 内容将作为
Signal返回,因此您可以通过调用信号来访问值:content().title。更改内容的语言
要更改内容的语言,您可以使用
useLocale函数提供的setLocale函数。这允许您设置应用程序的区域设置,并相应更新内容。创建一个用于切换语言的组件:
src/app/locale-switcher.component.ts复制代码复制代码到剪贴板
然后,在
app.component.ts中使用此组件:src/app/app.component.ts复制代码复制代码到剪贴板
配置TypeScript
Intlayer使用模块扩充(Module Augmentation)来获得TypeScript的好处,并使您的代码库更健壮。


请确保您的TypeScript配置包含了自动生成的类型。
复制代码到剪贴板
Git配置
建议忽略由Intlayer生成的文件。这可以避免将它们提交到您的Git仓库。
为此,您可以将以下说明添加到您的 .gitignore 文件中:
复制代码到剪贴板
VS Code 扩展
为了提升您在Intlayer中的开发体验,您可以安装官方的 Intlayer VS Code 扩展。
该扩展提供:
- 翻译键的自动补全。
- 缺失翻译的实时错误检测。
- 已翻译内容的内联预览。
- 轻松创建和更新翻译的快速操作。
有关如何使用该扩展的更多详细信息,请参阅 Intlayer VS Code 扩展示例文档。
深入了解
想要深入了解,您可以实现可视化编辑器或使用CMS外部化您的内容。