React国际化中英文切换实现

目录

概况

安装

文件结构

引入

使用

正常使用

传参使用


概况

react-intl-universal 是一个国际化库,专门为 React 应用提供多语言支持。与 React 原生的 react-intl 相比,react-intl-universal 支持从远程服务器加载语言包,动态切换语言,并且可以不依赖于 React 组件。

GitHub地址:

GitHub - alibaba/react-intl-universal: Internationalize React apps. Not only for Component but also for Vanilla JS.Internationalize React apps. Not only for Component but also for Vanilla JS. - alibaba/react-intl-universalhttps://github.com/alibaba/react-intl-universal

安装

可以通过 npm 或 yarn 来安装该依赖,命令如下:

复制代码
npm install react-intl-universal --save
# 或者
yarn add react-intl-universal

文件结构

安装依赖完成后就可以创建对应的文件夹以用来保存各类语种的翻译。

一般情况下,都存放在根目录==> src ==> locales 目录下。

这里我只做了中英文的翻译,如果你想添加更多语种则可以添加对应的json文件。

注意!这里创建的文件类型是json而不是js。

引入

初始化react-intl-universal插件,

通常在应用启动时(如在 componentDidMountuseEffect 中)初始化 react-intl-universal,并加载对应的语言包。

一般情况下这个引入过程都应该放在入口文件上,或者顶级layout中,以方便做中英文切换的按钮。

javascript 复制代码
import React, { Component } from 'react'
import intl from 'react-intl-universal';
const locales = {
  "en": require('../locales/en-US.json'),
  "zh": require('../locales/zh-CN.json'),
};

export default class index extends Component {
  constructor(props) {
    super(props);
    this.state = {
      currentLocale: this.props?.baseInfo?.currentLocale || 'zh',
    }
  }
  componentDidMount() {
    this.loadLocales()
  }
  loadLocales() {
    const { currentLocale } = this.state
    intl.init({
      currentLocale: currentLocale,
      locales,
    }).then(() => {});
  }

  render() {
    return (

    )
  }
}

使用

假如我现在有两个文件,一个en-US.json,一个zh-CN.json。内容分别如下。

javascript 复制代码
// en-US.json
{
  "HELLO": "Hello!",
  "WELCOME": "Welcome to {place}."
}

// zh-CN.json
{
  "HELLO": "你好!",
  "WELCOME": "欢迎来到{place}。"
}

正常使用

在对应组件中引入 intl 然后使用 intl.get 就可以获取对应的翻译内容。

注意!这里get方法内传入的字符串,必须与zh-CN.json和en-US.json中对应翻译的ID一致,且区分大小写。

javascript 复制代码
import intl from 'react-intl-universal';


const greeting = intl.get('HELLO');
console.log(greeting); // 输出: "Hello!" 或 "你好!"

传参使用

基本用法一致,传参的话可以根据当前语言也做一下判断。

javascript 复制代码
import intl from 'react-intl-universal';


const greeting = intl.get('WELCOME',{place: '百京'});
console.log(greeting); // 输出: "Welcome to 百京" 或 "欢迎来到百京"
相关推荐
kyriewen5 小时前
我手写了一个 EventEmitter,面试官追问了 6 个问题——第 4 个我没答上来
前端·javascript·面试
IT_陈寒5 小时前
Java的Date类又坑了我一次,改用时间戳真香
前端·人工智能·后端
山河木马6 小时前
矩阵专题2-怎么创建视图矩阵(uViewMatrix)
javascript·webgl·计算机图形学
小林攻城狮6 小时前
使用 Transport 节流解决 Vercel AI SDK 流式渲染卡死问题
前端·react.js
前端缘梦6 小时前
告别 TS 运行时类型漏洞!Zod 完整入门实战教程(前端 / 全栈必备)
前端·react.js·全栈
the_answer6 小时前
Webpack vs Vite 深度对比分析
前端·webpack
转转技术团队6 小时前
验证码识别实战:前端不写页面,改训模型了?
前端
MomentYY6 小时前
Temperature:AI 的“脑洞旋钮”
前端·llm·ai编程
远航_7 小时前
OpenSpec 完整详细介绍
前端·后端
召钱熏7 小时前
状态枚举正确≠渲染正确:一个语音按钮的状态机边界修复实录
android·前端