如何在Blazor Server App中进行全球化和本地化?
无法在Blazor Server App中找到全球化和本地化的有效示例, 我创建了自己的一个。这是代码示例。复制并测试...
答案 0 :(得分:0)
创建一个文件夹并将其命名为Resources
将以下资源文件(.resx
)添加到文件夹
Pages.Index.resx
:将字符串Greetings添加到Name列,然后问好!至
值列
Pages.Index.fr.resx
:将字符串Greetings添加到Name列和Bonjour!
进入“值”列
Pages.Index.de.resx
:将字符串Greetings添加到Name列和Hallo中
进入“值”列
将名为CultureSelector.razor的组件添加到“共享”文件夹:
@using System.Globalization
@inject NavigationManager NavigationManager
@using System.Threading
<div>@SelectedCulture</div>
<select value="@SelectedCulture" @onchange="OnSelected">
@foreach (var culture in Cultures)
{
<option value="@culture.Value">@culture.Caption</option>
}
</select>
@code {
private void OnSelected(ChangeEventArgs e)
{
var culture = (string)e.Value;
var uri = new Uri(NavigationManager.Uri)
.GetComponents(UriComponents.PathAndQuery, UriFormat.Unescaped);
var query = $"?culture={Uri.EscapeDataString(culture)}&" +
$"redirectUri={Uri.EscapeDataString(uri)}";
NavigationManager.NavigateTo("/Culture/SetCulture" + query, forceLoad: true);
}
public string SelectedCulture { get; set; } = Thread.CurrentThread.CurrentUICulture.Name;
public class CultureData
{
public string Caption { get; set; }
public string Value { get; set; }
}
public List<CultureData> Cultures { get; set; } = new List<CultureData>()
{
new CultureData() { Caption = "English", Value = "en-US" },
new CultureData() { Caption = "French", Value = "fr-FR" },
new CultureData() { Caption = "German", Value = "de-DE" },
};
}
像这样在MainLayout中实例化CultureSelector组件:
@inherits LayoutComponentBase
@using System.Linq;
@using System.Reflection
@using Microsoft.AspNetCore.Components
<div class="sidebar">
<NavMenu />
</div>
<div class="main">
<div class="top-row px-4">
<CultureSelector></CultureSelector>
<a href="https://docs.microsoft.com/aspnet/" target="_blank">About</a>
</div>
<div class="content px-4">
@Body
</div>
</div>
@page "/"
@using Microsoft.Extensions.Localization
@inject Microsoft.Extensions.Localization.IStringLocalizer<Index> localizer
<h1>@localizer["Greetings"].Value</h1>
@code{ }
public void ConfigureServices(IServiceCollection services)
{
services.AddLocalization(options => options.ResourcesPath =
"Resources");
services.AddRazorPages();
services.AddServerSideBlazor();
services.AddSingleton<WeatherForecastService>();
services.AddControllers();
services.Configure<RequestLocalizationOptions>(options =>
{
// define the list of cultures your app will support
var supportedCultures = new List<CultureInfo>()
{
new CultureInfo("en-US"),
new CultureInfo("fr-FR"),
new CultureInfo("de-DE")
};
// set the default culture
options.DefaultRequestCulture = new RequestCulture("en-US");
options.SupportedCultures = supportedCultures;
options.SupportedUICultures = supportedCultures;
});
}
public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
{
if (env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
}
else
{
app.UseExceptionHandler("/Error");
app.UseHsts();
}
app.UseRequestLocalization(
app.ApplicationServices.GetService<IOptions<RequestLocalizationOptions>>
().Value);
app.UseHttpsRedirection();
app.UseStaticFiles();
app.UseRouting();
app.UseEndpoints(endpoints =>
{
// enable controllers for the culture controller
endpoints.MapControllers();
endpoints.MapBlazorHub();
endpoints.MapFallbackToPage("/_Host");
});
}
将Controller类添加到Controllers文件夹(如果存在。如果不添加一个) 将其命名为CultureController.cs
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Localization;
using Microsoft.AspNetCore.Mvc;
using Microsoft.Extensions.Logging;
namespace <Put here the namespace of your app>.Controllers
{
[Route("[controller]/[action]")]
public class CultureController : Controller
{
public IActionResult SetCulture(string culture, string redirectUri)
{
if (culture != null)
{
HttpContext.Response.Cookies.Append(
CookieRequestCultureProvider.DefaultCookieName,
CookieRequestCultureProvider.MakeCookieValue(
new RequestCulture(culture)));
}
return LocalRedirect(redirectUri);
}
public IActionResult ResetCulture(string redirectUri)
{
HttpContext.Response.Cookies.Delete(CookieRequestCultureProvider.DefaultCookieName);
return LocalRedirect(redirectUri);
}
}
}