React 專案配置 i18n 多國語系
· 閱讀時間約 8 分鐘
前言:
最近我在更新公司內部的前端 Codebase,其中一項任務是為應用加入多國語系(i18n)的支持。雖然在舊專案上一直有在使用 i18n 的功能,但這是我第一次接觸 i18n 的配置,正好藉此機會把學習過程和實作細節記錄下來。
主要工具介紹:i18next 與 react-i18next
在研究 React 應用程式中的多國語系解決方案時,18next 和 react-i18next 是最常被推薦的組合。
i18next
18next 是一個強大且可擴充的國際化庫,專門用來處理語言轉換。i18next 的特點是可以跨框架使用,這讓它成為前後端通用的國際化解決方案。它的核心功能包括語言偵測、語言切換,以及使用 JSON 語系檔案來管理文本內容。
此外,i18next 支援多種插件,例如:當你想要根據用戶的偏好來設定語言時,可以透過語言檢測插件來判斷用戶的語言喜好。它還支援 HTTP 加載器,可以動態從伺服器端載入翻譯文件。
react-i18next
react-i18next 則是 i18next 的 React 封裝。它的目的是讓 React 開發者能更方便地將 i18next 的功能整合進應用程式中。它提供了很多直觀的工具,例如 Hook (useTranslation
) 和高階元件 (withTranslation
),讓我們能夠以更符合 React 思維的方式處理翻譯工作。
專案需求
大致理解這些工具的作用後,我開始分析專案的需求。根據過去舊專案的 i18n 使用情況,目前的需求至少要包括:
- 支持中英文切換:應用需要支持用戶隨時切換介面語言。
- 根據用戶的瀏覽器語言自動設置語言:提升用戶體驗,讓應用自動選擇最合適的語言。
- 命名空間來管理翻譯文檔:不同的功能模組應該有各自獨立的翻譯檔,避免文檔過於混亂。比如,通用部分 (
common
) 和應用特定部分 (app
)。