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 百京" 或 "欢迎来到百京"
相关推荐
Harriet嘉15 分钟前
解决Chrome 140以上版本“此扩展程序不再受支持,因此已停用”问题 axure插件安装问题
前端·chrome
FuckPatience21 分钟前
前端Vue 后端ASP.NET Core WebApi 本地调试交互过程
前端·vue.js·asp.net
Kingsdesigner25 分钟前
从平面到“货架”:Illustrator与Substance Stager的包装设计可视化工作流
前端·平面·illustrator·设计师·substance 3d·平面设计·产品渲染
一枚前端小能手35 分钟前
🔍 那些不为人知但是好用的JS小秘密
前端·javascript
屿小夏37 分钟前
JSAR 开发环境配置与项目初始化全流程指南
前端
微辣而已38 分钟前
next.js中实现缓存
前端
北城以北88881 小时前
Vue-- Axios 交互(二)
javascript·vue.js·交互
Dcc1 小时前
纯 css 实现前端主题切换+自定义方案
前端·css
Zuckjet_1 小时前
第 7 篇:交互的乐趣 - 响应用户输入
前端·javascript·webgl
我总是词不达意1 小时前
vue3 + el-upload组件集成阿里云视频点播从本地上传至点播存储
前端·vue.js·阿里云·elementui