#localization #blazor #blazor-server-side
#локализация #blazor #blazor-на стороне сервера
Вопрос:
Как выполнить глобализацию и локализацию в серверном приложении Blazor?
Не имея возможности найти рабочий образец глобализации и локализации в серверном приложении Blazor, я создал свой собственный. Вот пример кода. Скопируйте и протестируйте…
Ответ №1:
-
Создайте папку и назовите ее Ресурсы
-
Добавьте в папку следующие файлы ресурсов (
.resx
)Pages.Index.resx
: Добавьте строку Приветствия в столбец Имя и Привет! в столбец значенийPages.Index.fr.resx
: Добавьте строку приветствия в столбец Имени и Бонжур! в столбец значенийPages.Index.de.resx
: Добавьте строку Приветствия в столбец Имя и Привет в столбец Значение -
Добавьте компонент с именем CultureSelector.razor в общую папку:
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)}amp;"
$"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" },
};
}
Создайте экземпляр компонента CultureSelector в mainLayout следующим образом:
@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://learn.microsoft.com/aspnet/" target="_blank">About</a>
</div>
<div class="content px-4">
@Body
</div>
</div>
Использование (Index.razor)
@page "/"
@using Microsoft.Extensions.Localization
@inject Microsoft.Extensions.Localization.IStringLocalizer<Index> localizer
<h1>@localizer["Greetings"].Value</h1>
@code{ }
Startrup.cs
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");
});
}
Добавьте класс контроллера в папку 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);
}
}
}
Комментарии:
1. Я внедрил ваше решение, и оно работает, но у меня есть вопрос, что, если вы хотите создать файл ресурсов с общими ресурсами, которые вы будете использовать на нескольких страницах / компонентах, например, текст, сохранить, ошибка, удалить, обновить Я хочу добавить такие тексты в ресурс и использоватьэто вместо того, чтобы копировать их повсюду