2000字范文,分享全网优秀范文,学习好帮手!
2000字范文 > 有关ASP.NET Core 中的多语言支持的详细介绍

有关ASP.NET Core 中的多语言支持的详细介绍

时间:2020-08-08 23:57:45

相关推荐

有关ASP.NET Core 中的多语言支持的详细介绍

后端开发|C#.Net教程

,Core,语言

后端开发-C#.Net教程

本篇文章主要介绍了 Core 中的多语言支持(Localization) ,具有一定的参考价值,有兴趣的可以了解一下

android 裁剪图片源码,vscode里设置快捷键,ubuntu开动命令,深度清理tomcat缓存,怎样腌制爬虫,php产品管理系统,seo论坛和sem论坛的区别,网站页面源码下载lzw

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

思科源码,vscode rn自动补全,进入Ubuntu失败,tomcat怎么允许项目,爬虫需要,php log输出,seo系统好养吗,音频视频点播网站源码,h5 代码模板lzw

哪里有免费的源码,vscode 自己写模板,ubuntu 分屏幕,tomcat满荷负载,sqlite中opt什么意思,迷你世界自制爬虫载具怎么做,php中插入html,皮革seo优化费用,时时彩网站源码,网站模板大全图片lzw

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

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

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

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

@using Microsoft.AspNetCore.Mvc.Localization@inject IViewLocalizer Localizer@ViewData["Title"] - @Localizer["SiteTitle"]

接着在 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

这时运行 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.” 问

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。