Angular12和WebApi多語言使用

来源:https://www.cnblogs.com/yuxl01/archive/2022/04/07/16112946.html
-Advertisement-
Play Games

1.安裝ngx-translate 運行下麵命令安裝@ngx-translate/core和@ngx-translate/http-loader: npm install @ngx-translate/core --save npm install @ngx-translate/http-loade ...


1.安裝ngx-translate

運行下麵命令安裝@ngx-translate/core和@ngx-translate/http-loader:

npm install @ngx-translate/core --save
npm install @ngx-translate/http-loader –save
2.配置多語言

1.在根模塊app.module.ts下導入TranslateModule,並定義配置

export function HttpLoaderFactory(http: HttpClient) {
  return new TranslateHttpLoader(http, './assets/i18n/', '.json');
}
@NgModule({
  imports: [
    TranslateModule.forRoot({
      loader: {
        provide: TranslateLoader,
        useFactory: HttpLoaderFactory,
        deps: [HttpClient],
      },
    }),
  ],
  providers: [
    { provide: NZ_I18N, useValue: en_US },
  ]
})

2.在./src/assets/i18n下創建多語言文件en_US.jsonzh-CN.json,多語言的值是json形式展示

cd ./src/assets/i18n
ls en_US.json
ls zh-CN.json

3.註入TranslateService服務,並定義設置語言的函數,例如調用函數切換為英文setLanguage('en_US')

//註入多語言服務
constructor(private translate: TranslateService){}
//設置語言
async setLanguage(lang: FrontEndLanguage) {
  await this.translate.use(lang).toPromise();
}
3.設置自定義文件夾

如果你想自定義多語言文件存放的路徑,那就必須實現TranslateLoader

1.繼承TranslateLoader,實現方法

export class CustomTranslateHttpLoader implements TranslateLoader {
  constructor(private http: HttpClient) { }

  getTranslation(lang: string) {
    const prefix = './assets/language/';
    const suffix = '.json';
    this.http.head
    return this.http.get(`${prefix}${lang}${suffix}`, { headers: { 'Content-Type': 'application/json;charset=utf-8' } });
  }
}

2.然後在app.module.ts下的HttpLoaderFactory中使用自定義的載入器

export function HttpLoaderFactory(http: HttpClient) {
  return new CustomTranslateHttpLoader(http);
}
4.多語言使用

1.在後端ts獲取多語言信息,首先註入TranslateService服務

//註入多語言服務
constructor(private translate: TranslateService){}
//獲取多語言值
this.translate.instant(summary);

2.在html中給表格的列頭添加多語言值,“th”:{"Name":'名稱'}

 <th nzAlign="center" nzWidth="20%"  ><span style="color: red;"> &nbsp;</span>{{"th.Name"|translate}}</th>
5.WebAPI實現多語言

首先為什麼需要後端多語言,前端不是有了嗎?主要針對一些特殊提示,只能後端返回的場景,如果你對Asp .net管道模型或者webAPI框架有足夠深入,可以使用HttpModule或者根據你的業務需要,自己在框架上擴展都可以,此處使用DelegatingHandler在webAPI管道中攔截的方式實現,主要實現步驟如下:

1.首先需要客戶端在請求頭帶上語言表示當前請求的語言類型,然後web項目中創建資源文件

2.實現DelegatingHandler,以作為攔截輸出

public class CultureDelegatingHandler : DelegatingHandler
{ 
    protected  override Task<HttpResponseMessage> SendAsync(HttpRequestMessage request, CancellationToken cancellationToken)
    {
        request.Headers.TryGetValues("culture", out IEnumerable<string> values);
        if (values != null && values.Count() > 0)
       {
            string  language =  values.FirstOrDefault().Replace('_', '-');

            switch (language)
            {
                case "EN":
                     language = "en_us";
                    break;
                case "ZH":
                     language = "zh-CN";
                    break;
            }
         
            Thread.CurrentThread.CurrentCulture = Thread.CurrentThread.CurrentUICulture = CultureInfo.GetCultureInfo(language);
        }
        return base.SendAsync(request, cancellationToken);
    }
}

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 鏡像下載、功能變數名稱解析、時間同步請點擊 阿裡雲開源鏡像站 OneBlog是什麼? OneBlog,一個簡潔美觀、功能強大並且自適應的Java博客。使用springboot開發,前端使用Bootstrap。支持移動端自適應,配有完備的前臺和後臺管理功能。 簡單瞭解了OneBlog後,下麵就跟隨博主一起看下 ...
  • 1.併發事務問題 1)臟讀:一個事物讀到另一個事務還沒有提交的數據。 2)不可重覆讀:一個事務先後讀取同一條記錄,但兩次讀取的數據不同,稱之為不可重覆讀。 3)幻讀:一個事務按照條件查詢數據時,沒有對應的數據行,但是在插入數據時,又發現這行數據已經存在,好像出現了“幻影”。 2.事務隔離級別 隔離級 ...
  • 1. LOAD DATA INFILE 為什麼比 INSERT 快? 2. sysbench 壓測 MySQL 的四個標準步驟。 3. 怎麼讓 sysbench 支持 LOAD DATA LOCAL INFILE 命令,讓導數速度提升 30%? ...
  • 為了更好的理解,我們使用 eTS 開發了一款如下動圖所示的井字過三關游戲來講解分散式數據管理在應用中的使用。 ...
  • 我們通過知識體系新開發的幾個基於 OpenHarmony3.1 Beta 標準系統的樣例:分散式音樂播放、傳炸彈、購物車等樣例,分別介紹下音樂播放、顯示動畫、動畫轉場(頁面間轉場)三個進階技能。 ...
  • 1. Parcel 簡介 在 IPC 過程中,發送方可以使用 Parcel 提供的寫方法,將待發送的數據以特定格式寫入Parcel對象。接收方可以使用 Parcel 提供的讀取方法從 Parcel 對象中讀取特定格式的數據。 Parcel 實例的預設容量為200KB。如果您想要更多或更少,請使用 s ...
  • 除了 OpenHarmony 的開發知識賦能,本期系列課程也關註開發者們的綜合能力培養,涵蓋如何啃論文,開源社區如何運轉,如何領航職場、通關面試、規劃職業生涯等內容。 ...
  • Android可視化埋點是Android全埋點的增強。開發者可以將App界面同步至DTM界面,併在DTM界面通過可視化點擊的方式添加埋點事件。目前Android可視化埋點包含兩種埋點方式:普通可視化埋點和按Tag模板埋點。 相比於代碼埋點,可視化埋點有以下優勢: 研發人員僅需要完成DTM SDK集成 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...