使用 Core 2.2 本地化的 Razor 页面不起作用
Razor Page using Core 2.2 Localization not working
我有一个 .NET Core 2.2 项目
我的启动程序中有以下代码
配置服务方法
services.AddLocalization(options => options.ResourcesPath = "Resources");
services.AddMvc()
.AddViewLocalization(LanguageViewLocationExpanderFormat.Suffix)
.AddDataAnnotationsLocalization();
配置方法
app.UseStaticFiles();
app.UseCookiePolicy();
var supportedCultures = new[]
{
new CultureInfo("en-US"),
new CultureInfo("es-ES"),
};
app.UseRequestLocalization(new RequestLocalizationOptions
{
DefaultRequestCulture = new RequestCulture("en-US"),
// Formatting numbers, dates, etc.
SupportedCultures = supportedCultures,
// UI strings that we have localized.
SupportedUICultures = supportedCultures
});
app.UseStaticFiles();
app.UseStaticFiles();
app.UseMvc();
我的索引里有 Page.csHtml
@page
@using Microsoft.AspNetCore.Mvc.Localization
@model IndexModel
@inject IViewLocalizer Localizer
@{
ViewData["Title"] = "Error";
}
<h3>Welcome to ASP.NET Localization</h3>
<p>This is Localization</p>
<h2>@Localizer["Overview"]</h2>
我在 Index.cshtml.cs
中使用了以下方法
private readonly IStringLocalizer<IndexModel> Localizer;
public IndexModel(IStringLocalizer<IndexModel> localizer)
{
Localizer = localizer;
}
我已经创建了一个资源文件
\Resources\Index.es.resx
目前有一个概览键。
我加载应用程序并尝试将文化更改为
https://localhost:44345/?culture=es-ES
但是字符串并没有像我预期的那样改变!
我用的是dotnet core2.1,步骤应该是一样的
- 创建路由文化提供者:
public class RouteValueRequestCultureProvider : IRequestCultureProvider
{
private readonly CultureInfo[] _cultures;
public RouteValueRequestCultureProvider(CultureInfo[] cultures)
{
_cultures = cultures;
}
/// <summary>
/// get {culture} route value from path string,
/// </summary>
/// <param name="httpContext"></param>
/// <returns>ProviderCultureResult depends on path {culture} route parameter, or default culture</returns>
public Task<ProviderCultureResult> DetermineProviderCultureResult(HttpContext httpContext)
{
var defaultCulture = "en";
var path = httpContext.Request.Path;
if (string.IsNullOrWhiteSpace(path))
{
return Task.FromResult(new ProviderCultureResult(defaultCulture));
}
var routeValues = httpContext.Request.Path.Value.Split('/');
if (routeValues.Count() <= 1)
{
return Task.FromResult(new ProviderCultureResult(defaultCulture));
}
if (!_cultures.Any(x => x.Name.ToLower() == routeValues[1].ToLower()))
{
return Task.FromResult(new ProviderCultureResult(defaultCulture));
}
return Task.FromResult(new ProviderCultureResult(routeValues[1]));
}
}
- 将
RouteValueRequestCultureProvider
添加到文化提供商列表的顶部:
services.Configure<RequestLocalizationOptions>(ops =>
{
ops.DefaultRequestCulture = new RequestCulture("en");
ops.SupportedCultures = cultures.OrderBy(x=>x.EnglishName).ToList();
ops.SupportedUICultures = cultures.OrderBy(x => x.EnglishName).ToList();
// add RouteValueRequestCultureProvider to the beginning of the providers list.
ops.RequestCultureProviders.Insert(0,
new RouteValueRequestCultureProvider(cultures));
});
- 为路由创建文化模板,所以我们得到 url 作为:
public class CultureTemplateRouteModelConvention : IPageRouteModelConvention
{
public void Apply(PageRouteModel model)
{
var selectorCount = model.Selectors.Count;
for (var i = 0; i < selectorCount; i++)
{
var selector = model.Selectors[i];
model.Selectors.Add(new SelectorModel
{
AttributeRouteModel = new AttributeRouteModel
{
Order = -1,
Template = AttributeRouteModel.CombineTemplates(
"{culture?}",
selector.AttributeRouteModel.Template),
}
});
}
}
}
- 配置服务以使用文化路线模板:
services.AddMvc()
.AddRazorPagesOptions(o => {
o.Conventions.Add(new CultureTemplateRouteModelConvention());
});
查看完整教程here。
- 对于创建语言下拉菜单,您可以按照描述手动创建它here or you may use this nugget package以使用更少的代码自动创建它:)
razor 页面的本地化版本应位于 Pages
文件夹中。所以 Index
razor 页面的本地化应该位于
\Resources\Pages\Index.es.resx
在链接教程中,您使用的是共享资源,因此您不应在 Resources 中为页面等创建子文件夹,而只需将每个 resx 文件命名为 ViewResource.xx.resx.
我有一个 .NET Core 2.2 项目
我的启动程序中有以下代码
配置服务方法
services.AddLocalization(options => options.ResourcesPath = "Resources");
services.AddMvc()
.AddViewLocalization(LanguageViewLocationExpanderFormat.Suffix)
.AddDataAnnotationsLocalization();
配置方法
app.UseStaticFiles();
app.UseCookiePolicy();
var supportedCultures = new[]
{
new CultureInfo("en-US"),
new CultureInfo("es-ES"),
};
app.UseRequestLocalization(new RequestLocalizationOptions
{
DefaultRequestCulture = new RequestCulture("en-US"),
// Formatting numbers, dates, etc.
SupportedCultures = supportedCultures,
// UI strings that we have localized.
SupportedUICultures = supportedCultures
});
app.UseStaticFiles();
app.UseStaticFiles();
app.UseMvc();
我的索引里有 Page.csHtml
@page
@using Microsoft.AspNetCore.Mvc.Localization
@model IndexModel
@inject IViewLocalizer Localizer
@{
ViewData["Title"] = "Error";
}
<h3>Welcome to ASP.NET Localization</h3>
<p>This is Localization</p>
<h2>@Localizer["Overview"]</h2>
我在 Index.cshtml.cs
中使用了以下方法 private readonly IStringLocalizer<IndexModel> Localizer;
public IndexModel(IStringLocalizer<IndexModel> localizer)
{
Localizer = localizer;
}
我已经创建了一个资源文件
\Resources\Index.es.resx
目前有一个概览键。
我加载应用程序并尝试将文化更改为
https://localhost:44345/?culture=es-ES
但是字符串并没有像我预期的那样改变!
我用的是dotnet core2.1,步骤应该是一样的
- 创建路由文化提供者:
public class RouteValueRequestCultureProvider : IRequestCultureProvider
{
private readonly CultureInfo[] _cultures;
public RouteValueRequestCultureProvider(CultureInfo[] cultures)
{
_cultures = cultures;
}
/// <summary>
/// get {culture} route value from path string,
/// </summary>
/// <param name="httpContext"></param>
/// <returns>ProviderCultureResult depends on path {culture} route parameter, or default culture</returns>
public Task<ProviderCultureResult> DetermineProviderCultureResult(HttpContext httpContext)
{
var defaultCulture = "en";
var path = httpContext.Request.Path;
if (string.IsNullOrWhiteSpace(path))
{
return Task.FromResult(new ProviderCultureResult(defaultCulture));
}
var routeValues = httpContext.Request.Path.Value.Split('/');
if (routeValues.Count() <= 1)
{
return Task.FromResult(new ProviderCultureResult(defaultCulture));
}
if (!_cultures.Any(x => x.Name.ToLower() == routeValues[1].ToLower()))
{
return Task.FromResult(new ProviderCultureResult(defaultCulture));
}
return Task.FromResult(new ProviderCultureResult(routeValues[1]));
}
}
- 将
RouteValueRequestCultureProvider
添加到文化提供商列表的顶部:
services.Configure<RequestLocalizationOptions>(ops =>
{
ops.DefaultRequestCulture = new RequestCulture("en");
ops.SupportedCultures = cultures.OrderBy(x=>x.EnglishName).ToList();
ops.SupportedUICultures = cultures.OrderBy(x => x.EnglishName).ToList();
// add RouteValueRequestCultureProvider to the beginning of the providers list.
ops.RequestCultureProviders.Insert(0,
new RouteValueRequestCultureProvider(cultures));
});
- 为路由创建文化模板,所以我们得到 url 作为:
public class CultureTemplateRouteModelConvention : IPageRouteModelConvention
{
public void Apply(PageRouteModel model)
{
var selectorCount = model.Selectors.Count;
for (var i = 0; i < selectorCount; i++)
{
var selector = model.Selectors[i];
model.Selectors.Add(new SelectorModel
{
AttributeRouteModel = new AttributeRouteModel
{
Order = -1,
Template = AttributeRouteModel.CombineTemplates(
"{culture?}",
selector.AttributeRouteModel.Template),
}
});
}
}
}
- 配置服务以使用文化路线模板:
services.AddMvc()
.AddRazorPagesOptions(o => {
o.Conventions.Add(new CultureTemplateRouteModelConvention());
});
查看完整教程here。
- 对于创建语言下拉菜单,您可以按照描述手动创建它here or you may use this nugget package以使用更少的代码自动创建它:)
razor 页面的本地化版本应位于 Pages
文件夹中。所以 Index
razor 页面的本地化应该位于
\Resources\Pages\Index.es.resx
在链接教程中,您使用的是共享资源,因此您不应在 Resources 中为页面等创建子文件夹,而只需将每个 resx 文件命名为 ViewResource.xx.resx.