VoerkaI18n是一款非常优秀的全新的开源国际化多语言解决方案,主要特性包括:
babel
插件自动导入t翻译函数。@voerkai18n/runtime
超过90%的测试覆盖率React
应用一般可以采用create-react-app
或Vite+"@vitejs/plugin-react
工具来创建工程。
本节介绍如何为Vite
+@vitejs/plugin-react
创建的工程添加voerkai18n
支持。
React
应用启用VoerkaI18n
国际化功能的完整工程化流程如下:
voerkai18n init
初始化多语言工程voerkai18n extract
提取要翻译的文本voerkai18n translate
进行自动翻译或人工翻译voerkai18n compile
编译语言包@voerkai18n/react
和@voerkai18n/vite
插件t
函数进行翻译完整的工程化流程请参见工程化,以下简要介绍如何在Vue
应用中使用VoerkaI18n
。
Vite
插件如果应用是采用Vite
+@vitejs/plugin-react
创建的工程,则可以通过配置@voerkai18n/vite
插件实现自动导入t
函数和翻译内容自动映射
等。
在vite.config.js
中配置导入安装@voerkai18n/vite
插件。
import { defineConfig } from 'vite'
import react from '@vitejs/plugin-react'
import Inspect from 'vite-plugin-inspect'
import Voerkai18nPlugin from "@voerkai18n/vite"
// https://vitejs.dev/config/
export default defineConfig({
plugins: [
Inspect(), // localhost:3000/__inspect/
Voerkai18nPlugin({
debug: true // 输出一些调试信息
}),
react()
]
})
详见@voerkai18n/vite插件介绍。
t
翻译函数t
翻译函数用来进行文件翻译,普通的React
应用t
翻译函数可以用在两个地方:
js
或ts
文件React
组件jsx、tsx
文件js|ts
文件中使用只需要从languages
直接导入t
函数即可。
import { t } from "./languages"
取决于您是从哪一个文件中导入,需要修改导入位置,可能类似这样:
import { t } from "./languages"
import { t } from "../languages"
import { t } from "../../languages"
import { t } from "../../../languages"
console.log(t("中华人民共和国"))
t
函数后就可以直接使用了。如果启用了@voerkai18n/vite
插件的autoImport
,则会自动导入t
函数,无需手动导入。React
组件中使用在React
组件中使用t
函数翻译与在js|ts
文件中使用的最大区别在于:当切换语言时,需要触发组件的重新渲染。为此我们需要在根应用配置Provider
。
使用VoerkaI18nProvider
包装应用根组件,本质上是创建了一个VoerkaI18nContext.Provider
。
// 1.当前语言Scope
import { i18nScope } from "./languages"
import { VoerkaI18nProvider } from "@voerkai18n/react"
export default App(){
return (
)
}
VoerkaI18nProvider
还具有一个fallback
属性,用来指定语言包加载未完成时显示一些如正在加载语言包...
等信息。
// 1.当前语言Scope
import { i18nScope } from "./languages"
import { VoerkaI18nProvider } from "@voerkai18n/react"
export default App(){
return (
正在加载语言包...
t
翻译函数接下来通过useVoerkaI18n
获取当前作用域的t
翻译函数。
import { useVoerkaI18n } from "@voerkai18n/react"
export function MyComponent(){
const { t } = useVoerkaI18n()
return (
{t("要翻译的内容")}
)
}
注意:
在组件中直接使用import { t } from "languages
也是可以工作的,因为本质上t
函数仅仅是一个普通的函数。但是当动态切换语言时,对应的组件不能自动重新渲染。因此,只有通过{ t } = useVoerkaI18n()
导入的t
函数,才可以在切换语言时自动重新渲染组件。
接下来在一般我们还需要实现语言切换的功能界面,useVoerkaI18n
提供了:
t
: 当前作用域的翻译函数language
: 当前激活语言名称defaultLanguage
: 默认语言名称changeLanguage(language)
: 用来切换当前语言languages
: 读取当应用支持的语言列表。
import { useVoerkaI18n } from "@voerkai18n/react"
export function MyComponent(){
const { t, activeLanguage,changeLanguage,languages,defaultLanguage } = useVoerkaI18n()
return (
{t("当前语言")}:{activeLanguage}
{t("默认语言")}:{defaultLanguage}
{
{/* 遍历出支持的所有语言 */}
languages.map(lang=>{
return ()
})}
)
}
项目地址VoerkaI18n
封装根组件const { t } = useVoerkaI18n()
来导入翻译函数const { changeLanguage } = useVoerkaI18n()
来访问切换语言的函数ts/js
文件中使用import { t } from "./languages"
来导入t
翻译函数@voerkai18n/vite
插件是可选的,仅仅普通ts/js
文件使用t
翻译函数时用来自动导入。Create React App
创建React
应用,则请参考voerki18n-loader