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 百京" 或 "欢迎来到百京"
相关推荐
高山我梦口香糖14 分钟前
[react] <NavLink>自带激活属性
前端·javascript·react.js
撸码到无法自拔19 分钟前
React:组件、状态与事件处理的完整指南
前端·javascript·react.js·前端框架·ecmascript
高山我梦口香糖19 分钟前
[react]不能将类型“string | undefined”分配给类型“To”。 不能将类型“undefined”分配给类型“To”
前端·javascript·react.js
代码cv移动工程师23 分钟前
HTML语法规范
前端·html
Elena_Lucky_baby1 小时前
实现路由懒加载的方式有哪些?
前端·javascript·vue.js
Domain-zhuo1 小时前
如何利用webpack来优化前端性能?
前端·webpack·前端框架·node.js·ecmascript
理想不理想v1 小时前
webpack如何自定义插件?示例
前端·webpack·node.js
小华同学ai1 小时前
ShowDoc:Star12.3k,福利项目,个人小团队的在线文档“简单、易用、轻量化”还专门针对API文档、技术文档做了优化
前端·程序员·github
一雨方知深秋1 小时前
智慧商城:封装getters实现动态统计 + 全选反选功能
开发语言·javascript·vue2·foreach·find·every
海威的技术博客1 小时前
关于JS中的this指向问题
开发语言·javascript·ecmascript