ASP.NET Core中的多语言支持的图文详解

互联网 17-9-5
本篇文章主要介绍了ASP.NET Core 中的多语言支持(Localization) ,具有一定的参考价值,有兴趣的可以了解一下

首先在 Startup 的 ConfigureServices 中添加 AddLocalization 与 AddViewLocalization 以及配置 RequestLocalizationOptions (这里假设使用英文与中文):

public void ConfigureServices(IServiceCollection services)  {    services.AddLocalization(options => options.ResourcesPath = "Resources");      services.AddMvc()      .AddViewLocalization(LanguageViewLocationExpanderFormat.Suffix);      services.Configure<RequestLocalizationOptions>(      opts =>      {        var supportedCultures = new List<CultureInfo>        {          new CultureInfo("en-US"),          new CultureInfo("zh-CN")        };        opts.SupportedCultures = supportedCultures;        opts.SupportedUICultures = supportedCultures;      });  }

在 Startup 的 Configure() 方法中应用 RequestLocalizationOptions :

var requestLocalizationOptions = app.ApplicationServices.GetService<IOptions<RequestLocalizationOptions>>().Value;  app.UseRequestLocalization(requestLocalizationOptions);

然后在 _Layout.cshtml 视图中通过 IViewLocalizer 接口以多语言的方式显示页面标题的后缀:

@using Microsoft.AspNetCore.Mvc.Localization  @inject IViewLocalizer Localizer  <!DOCTYPE html>  <html>  <head>    <title>@ViewData["Title"] - @Localizer["SiteTitle"]</title>  </head>  <body>  </body>  </html>

接着在 ASP.NET Core Web 项目中创建 Resources 文件夹,在其中分别添加 Views.Shared._Layout.en-Us.resx 与 Views.Shared._Layout.zh-CN.resx 文件, Views.Shared._Layout.resx 文件,并添加 "SiteTitle" 所对应的语句文字:

1)Views.Shared._Layout.en-Us.resx

2)Views.Shared._Layout.zh-CN.resx

这时运行 ASP.NET Core 站点,就会根据浏览器的语言设置(Accept-Language header)、或者 culture 查询参数、或者 .AspNetCore.Culture Cookie 值显示对应语言的文字:

需要注意的地方:千万不要添加不带语言名称的 Views.Shared._Layout.en-Us.resx ,不然添加代码语言名称的 .resx 文件时会遇到 "Custom tool ResXFileCodeGenerator failed to produce an output for input file ... but did not log a specific error." 问。

以上就是ASP.NET Core中的多语言支持的图文详解的详细内容,更多内容请关注技术你好其它相关文章!

来源链接:
免责声明:
1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险
2.本文版权归属原作所有,仅代表作者本人观点,不代表本站的观点或立场
标签: 支持
上一篇:php获取远程图片并下载保存到本地的方法分析 下一篇:ASP.NET Core Razor页面路由的详细介绍

相关资讯