贝利信息

Blazor IStringLocalizer 多语言实现教程

日期:2025-12-13 00:00 / 作者:月夜之吻
Blazor 多语言核心是 IStringLocalizer + .resx 资源文件 + 语言切换逻辑,不依赖 JS;需在 Program.cs 注册 AddLocalization(),按规范命名资源文件(如 SharedResource.zh-CN.resx),组件中 @inject IStringLocalizer 使用,Server/WASM 切换文化方式不同但均原生支持。

Blazor 中使用 IStringLocalizer 实现多语言,核心是结合 .NET 的本地化服务 + 资源文件(.resx)+ 语言切换逻辑。它不依赖 JavaScript,完全在 C# 层完成,适合 Server、WASM 和 Hybrid 项目。

配置本地化服务

Program.cs(.NET 6+)中注册本地化服务:

准备资源文件(.resx)

资源文件必须按命名规范放置,Blazor 才能自动匹配:

在组件中注入并使用 IStringLocalizer

以 Razor 组件为例(如 Counter.razor):

动态切换语言并持久化用户选择

切换语言本质是改变当前线程/请求的 CultureInfo,并在客户端保存偏好:

基本上就这些。关键点是资源文件命名、注入方式、以及区分 Server/WASM 的文化切换机制。不需要第三方库,.NET 原生支持很稳。