1. 程式人生 > 程式設計 >ASP.NET Core MVC 中實現中英文切換的示例程式碼

ASP.NET Core MVC 中實現中英文切換的示例程式碼

  哈嘍..大家好 很久沒有更新了,今天就來一篇最近開發用到的功能,那就是中英文切換,這個實際上也不是高大上,先說一下原理,在.NET Core框架中給我們提供了全球化的類,叫做Localization,其官方的文件地址傳送門。

  在我的專案中,我是這樣操作的,你想用別的方式,也可以看文件自己去搞。這個已經不是什麼新鮮的東西了,只是網上的實現有些問題,不容易明白。

  我們無需任何Nuget包,因為它是在Microsoft.AspNetCore.Mvc.Localization中,那麼我們直接在.NET Core 框架中新增 Localization 服務。

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; 
            opts.RequestCultureProviders = new List<IRequestCultureProvider>{
              new X_DOVERequestCultureProvider()
            };
        });
      services.AddControllersWithViews();
    }

  嗯,這個程式碼是.NET Core 3.1 的 應該不會有太大區別吧?那個X_DOVERequestCultureProvider是我們自定義實現的,寫入了一些規則,我們看一下。

public class X_DOVERequestCultureProvider : RequestCultureProvider
  {
    public override Task<ProviderCultureResult> DetermineProviderCultureResult(HttpContext httpContext)
    {
      var CULTURE_String = "CULTURE";
      var CultureCookie = httpContext.Request.Cookies[CULTURE_String]?.ToString() ?? "";
      if (string.IsNullOrWhiteSpace(CultureCookie))
      {
        CultureCookie = "zh-CN";
        httpContext.Response.Cookies.Append(key: CULTURE_String,value: CultureCookie,options: new CookieOptions() { Expires = DateTime.Now.AddYears(1) });
      }
      return Task.FromResult(new ProviderCultureResult(CultureCookie));
    }
  }

  首先我們應該知道RequestCultureProvider,它是一個在框架自身包括的 .net core 提供的,我們繼承它重寫了它的抽象類,在其中獲取了httpContext的Cookies值,然後進行判斷,如果沒有咱們就不給它進行一個輸出了,否則它還是我們的zh-CN 就是中文。

  對,別忘記了要在Configure中使用中間價

 app.UseRequestLocalization(
        options:app.ApplicationServices
        .GetService<IOptions<RequestLocalizationOptions>>().Value);

  隨後我們應該定義我們的配置檔案,建立一個資料夾,放進去,它應當和上面Startup中的資料夾相同,隨後建立對應的檢視位置,一個英文一箇中文,一定要注意後面對應的en-Us 和 zh-CN 要相同哦。

ASP.NET Core MVC 中實現中英文切換的示例程式碼

  就現在我們在檢視中最上面匯入包,然後對應字典就可以了。

@using Microsoft.AspNetCore.Mvc.Localization
@inject IViewLocalizer Localizer

<section class="copyright"> @Localizer["section1"] <a href="https://github.com/zaranetCore/amusinghoS" rel="external nofollow" > | GitHub</a></section>

  你肯定知道該怎麼辦了,對的你可以去修改Cookies來操作當前httpContext中的合約,但儘管如何,我們只是重寫了cookies的,還沒有重寫url的,

<script>
  $(function () {
    $("#language").change(function (e) {
      var opt = $("#language").val();
      if (opt == 1) {
        document.cookie = 'CULTURE=zh-CN';
        location.reload();
      } else if(opt == 2) {
        document.cookie = 'CULTURE=en-US';
        location.reload();
      }
    });
  });
</script>

  好吧,歡迎各位同學把重寫url的方法寫寫出來,回覆在本篇文章中..我們看一下效果,好的就這樣吧..

ASP.NET Core MVC 中實現中英文切換的示例程式碼

到此這篇關於ASP.NET Core MVC 中實現中英文切換的示例程式碼的文章就介紹到這了,更多相關ASP.NET Core MVC 中英文切換內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!