您好,登錄后才能下訂單哦!
小編給大家分享一下ASP.NET Core中多語(yǔ)言支持的示例分析,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
首先在 Startup 的 ConfigureServices 中添加 AddLocalization 與 AddViewLocalization 以及配置 RequestLocalizationOptions (這里假設(shè)使用英文與中文):
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() 方法中應(yīng)用 RequestLocalizationOptions :
var requestLocalizationOptions = app.ApplicationServices.GetService<IOptions<RequestLocalizationOptions>>().Value; app.UseRequestLocalization(requestLocalizationOptions);
然后在 _Layout.cshtml 視圖中通過(guò) IViewLocalizer 接口以多語(yǔ)言的方式顯示頁(yè)面標(biāo)題的后綴:
@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 項(xiàng)目中創(chuàng)建 Resources 文件夾,在其中分別添加 Views.Shared._Layout.en-Us.resx 與 Views.Shared._Layout.zh-CN.resx 文件, Views.Shared._Layout.resx 文件,并添加 "SiteTitle" 所對(duì)應(yīng)的語(yǔ)句文字:
1)Views.Shared._Layout.en-Us.resx
2)Views.Shared._Layout.zh-CN.resx
這時(shí)運(yùn)行 ASP.NET Core 站點(diǎn),就會(huì)根據(jù)瀏覽器的語(yǔ)言設(shè)置(Accept-Language header)、或者 culture 查詢參數(shù)、或者 .AspNetCore.Culture Cookie 值顯示對(duì)應(yīng)語(yǔ)言的文字:
需要注意的地方:千萬(wàn)不要添加不帶語(yǔ)言名稱的 Views.Shared._Layout.en-Us.resx ,不然添加代碼語(yǔ)言名稱的 .resx 文件時(shí)會(huì)遇到 "Custom tool ResXFileCodeGenerator failed to produce an output for input file ... but did not log a specific error." 問(wèn)
看完了這篇文章,相信你對(duì)“ASP.NET Core中多語(yǔ)言支持的示例分析”有了一定的了解,如果想了解更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。