开发React应用的多语言支持最佳实践

前言

VoerkaI18n是一款非常优秀的全新的开源国际化多语言解决方案,主要特性包括:

  • 全面工程化解决方案,提供初始化、提取文本、自动翻译、编译等工具链支持。
  • 符合直觉,不需要手动定义文本Key映射。
  • 强大的插值变量格式化器机制,可以扩展出强大的多语言特性。
  • 支持babel插件自动导入t翻译函数。
  • 支持nodejs、浏览器(vue/react/solid)等、React Native等任意JS场景
  • 采用工具链与运行时分开设计,发布时只需要集成很小的运行时。
  • 高度可扩展的复数、货币、数字等常用的多语言处理机制。
  • 翻译过程内,提取文本可以自动进行同步,并保留已翻译的内容。
  • 可以动态在线添加支持的语言
  • 支持发布后的在线打语言包补丁,修复翻译错误
  • 支持调用在线自动翻译对提取文本进行翻译。
  • 核心运行时@voerkai18n/runtime超过90%的测试覆盖率
  • 支持·TypeScript·开发

React应用一般可以采用create-react-appVite+"@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插件。

typescript 复制代码
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翻译函数可以用在两个地方:

  • 普通的jsts文件
  • React组件jsx、tsx文件

js|ts文件中使用

只需要从languages直接导入t函数即可。

javascript 复制代码
import { t } from "./languages"

取决于您是从哪一个文件中导入,需要修改导入位置,可能类似这样:

javascript 复制代码
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

  1. 配置根组件Provider

使用VoerkaI18nProvider包装应用根组件,本质上是创建了一个VoerkaI18nContext.Provider

jsx 复制代码
// 1.当前语言Scope
import { i18nScope } from "./languages"
import { VoerkaI18nProvider } from "@voerkai18n/react"

export default App(){
	return (
        <VoerkaI18nProvider scope={i18nScope}>
            <MyComponent/>
        <VoerkaI18nProvider/>
   )
}

VoerkaI18nProvider还具有一个fallback属性,用来指定语言包加载未完成时显示一些如正在加载语言包...等信息。

jsx 复制代码
// 1.当前语言Scope
import { i18nScope } from "./languages"
import { VoerkaI18nProvider } from "@voerkai18n/react"

export default App(){
	return (
        <VoerkaI18nProvider fallback={<div>正在加载语言包...</div>} scope={i18nScope}>
            <MyComponent/>
        <VoerkaI18nProvider/>
   )
}
  1. 组件中使用t翻译函数

接下来通过useVoerkaI18n获取当前作用域的t翻译函数。

jsx 复制代码
import { useVoerkaI18n } from "@voerkai18n/react"
export function MyComponent(){
     const { t } = useVoerkaI18n()
    return ( 
        <div>{t("要翻译的内容")}</div> 
    )
}

注意:

在组件中直接使用import { t } from "languages也是可以工作的,因为本质上t函数仅仅是一个普通的函数。但是当动态切换语言时,对应的组件不能自动重新渲染。因此,只有通过{ t } = useVoerkaI18n()导入的t函数,才可以在切换语言时自动重新渲染组件。

第四步:切换语言

接下来在一般我们还需要实现语言切换的功能界面,useVoerkaI18n提供了:

  • t: 当前作用域的翻译函数
  • language: 当前激活语言名称
  • defaultLanguage: 默认语言名称
  • changeLanguage(language): 用来切换当前语言
  • languages: 读取当应用支持的语言列表。
jsx 复制代码
import { useVoerkaI18n } from "@voerkai18n/react"

export function MyComponent(){
     const { t, activeLanguage,changeLanguage,languages,defaultLanguage } = useVoerkaI18n()
    return ( 
        <div>
            <h1>{t("当前语言")}:{activeLanguage}</h1>
            <h1>{t("默认语言")}:{defaultLanguage}</h1>
            <div> {
                {/* 遍历出支持的所有语言 */}
                languages.map(lang=>{
                return (<button 
                            key={lang.name}
                            οnclick={()=>changeLanguage(lang.name)}>
                            {lang.title}
                        </button>)
                })}
            </div>             
        </div> 
    )
} 

项目地址VoerkaI18n

小结

  • 使用<VoerkaI18nProvider scope={i18nScope}>封装根组件
  • const { t } = useVoerkaI18n()来导入翻译函数
  • 使用const { changeLanguage } = useVoerkaI18n()来访问切换语言的函数
  • 在普通ts/js文件中使用import { t } from "./languages"来导入t翻译函数
  • @voerkai18n/vite插件是可选的,仅仅普通ts/js文件使用t翻译函数时用来自动导入。
  • 如果使用Create React App创建React应用,则请参考voerki18n-loader
  • 完整示例见:
相关推荐
续亮~2 小时前
6、Redis系统-数据结构-05-整数
java·前端·数据结构·redis·算法
顶顶年华正版软件官方4 小时前
剪辑抽帧技巧有哪些 剪辑抽帧怎么做视频 剪辑抽帧补帧怎么操作 剪辑抽帧有什么用 视频剪辑哪个软件好用在哪里学
前端·音视频·视频·会声会影·视频剪辑软件·视频剪辑教程·剪辑抽帧技巧
托尼沙滩裤5 小时前
【js面试题】js的数据结构
前端·javascript·数据结构
不熬夜的臭宝5 小时前
每天10个vue面试题(一)
前端·vue.js·面试
不如喫茶去5 小时前
VUE自定义新增、复制、删除dom元素
前端·javascript·vue.js
长而不宰5 小时前
vue3+electron项目搭建,遇到的坑
前端·vue.js·electron
阿垚啊6 小时前
vue事件参数
前端·javascript·vue.js
过去式的美好7 小时前
vue前端通过sessionStorage缓存字典
前端·vue.js·缓存
Simaoya7 小时前
vue判断元素滚动到底部后加载更多
前端·javascript·vue.js
头顶一只喵喵7 小时前
Vue基础知识:Vue3.3出现的defineOptions,如何使用,解决了什么问题?
前端·javascript·vue.js·vue3