react-intl国际化在项目中的使用

前言

使用成熟的第三方库的国际化,可以直接使用封装好的方法,这个国际化的原理其实是使用了react 的第三方库react-intl ,感觉主要比较好的就是使用其中的模版,它的本质还是通过了Provider的形式

第一步新建文件夹,计划把所有的国际化相关的代码统统放到 src/locale 中以下是目录结构

src-local-languages (所有的翻译文件)-Provider (国际化包裹组件,其中调用国际化接口并合并最后注入)-index.ts(到处一些公共的语言相关的变量和方法)

1、项目入口 js文件

从入口 js 文件开始我们的工作,可以看到只使用了 IntlProvider 组件,并传入了当前的模块名字,在组件中通过模块名去请求后端的国际化内容

// 以下是 vite 的入口文件 main.tsx
import ReactDOM from 'react-dom/client'
import { Suspense } from 'react'
import 'amfe-flexible'import App from './App'// 国际的 Provider (包含 react-intl antd)
import IntlProvider from '@/locale/Provider'ReactDOM.createRoot(document.getElementById('root') as HTMLElement).render(<IntlProvider moduleCodes='baseline'><Suspense><App /></Suspense></IntlProvider>
)

2、locale/index.ts文件

  1. 定义了当前的语言

  2. 定义了当前的 languages 翻译内容

  3. 导出了非组件中使用intl的方法(简写了一些代码,其他组件中都使用了hooks的国际化写法,这里导出是为了方便组件外面使用)

import { createIntl, createIntlCache } from "react-intl";import en_us from "./languages/en-us";
import zh_cn from "./languages/zh-cn";
import zh_tw from "./languages/zh-tw";// 所有的语言map
let languages = {"en-us": en_us,"zh-cn": zh_cn,"zh-tw": zh_tw,
};// 当前的语言
const lang = localStorage.getItem("language") || "zh-cn";// 非组件中使用intl
const intl = createIntl({locale: localStorage.getItem("language") || "zh-cn",messages: languages[lang],},createIntlCache()
);// 简写 intl.formatMessage(使得业务中少些代码)
const i18n = (id: string,defaultMessage?: string,description?: string | object
) => {return intl.formatMessage({ id, defaultMessage, description });
};export { languages, lang, intl, i18n };

3、locale/Provider组件

入口的使用的 IntlProvider 定义如下,可以看到该组件做了以下操作

  1. 引入locale/index.ts文件中的 当前语言、所有的语言翻译

  2. 组件挂载后立马通过 moduleCodes 获取后端国际化内容然后合并本地的国际化内容(具体每个项目不同),成功合并后渲染所有的子页面 {init && children}

  3. 处理UI库的国际化(这里是antd)

import { useEffect, useState } from 'react';
import { ConfigProvider } from 'antd'
import { IntlProvider } from 'react-intl'
import 'dayjs/locale/zh-cn'
import dayjs from 'dayjs'
import enUS from 'antd/locale/en_US';
import zhCN from 'antd/locale/zh_CN';import { getIntl } from '@/api/user'
import { languages, lang } from '../index'dayjs.locale(lang )export default function Index(props: {children?: any,moduleCodes: string | Array<string>,
}) {let { children, moduleCodes } = propsconst [init, setInit] = useState(false)const [intl, setInel] = useState({})useEffect(() => {initData()}, [])const initData = async () => {// 接口请求获取国际化,并合并本地默认值let res = await getIntl(moduleCodes)let map = {}res.list.forEach((module: { [key: string]: string }) => {Object.keys(module).forEach(key => {Object.assign(map, module[key])})})setInel({ ...languages[lang], ...map })setInit(true)}return (<IntlProvider defaultLocale="zh-cn" locale={lang} messages={intl}><ConfigProvider locale={lang === 'en-us' ? enUS : zhCN}>{init && children}</ConfigProvider></IntlProvider>)
}

3、locale/languages

目前有两种语言文件 en-us.ts zh-cn.ts,导出一个键值对的对象

// en-us.ts
export default {"baseline.common.index": "No.",
};
//zh-cn.ts
export default {"baseline.common.index": "序号",
};

4、国际化的使用

这是函数组的使用,类组件的使用可以使用上面locale/index.ts导出的的 intl,具体的使用可以点进去看 react-intl 的定义

import { useIntl } from 'react-intl';function Component(){const intl = useIntl();useEffect(() => {// 测试intl.formatMessage({ id: 'baseline.common.index'});}, [])
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/21170.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

属性(property)

自学python如何成为大佬(目录):https://blog.csdn.net/weixin_67859959/article/details/139049996?spm1001.2014.3001.5501 1 创建用于计算的属性 在Python中&#xff0c;可以通过property&#xff08;装饰器&#xff09;将一个方法转换为属性&#xff0c;从而实现用于计算…

几种更新 npm 项目依赖的实用方法

引言 在软件开发的过程中&#xff0c;我们知道依赖管理是其中一个至关重要的环节。npm&#xff08;Node Package Manager&#xff09; 是 Node.js 的包管理器&#xff0c;它主要用于 Node.js 项目的依赖管理和包发布。随着项目的不断发展&#xff0c;依赖库的版本更新和升级成…

基于Win11下的Wireshark的安装和使用

Wireshark的安装和使用 前言一、Wireshark是什么简介 二、下载Wireshark下载过程查看自己电脑配置 三、安装Wireshark安装过程安装组件创建快捷方式winPacpNpcap 打开检验 四、使用Wireshark实施抓包捕获数据包 五、基于Wireshark使用显示过滤器简介使用方法注意ICMP的请求和应…

目标检测算法综述

1 研究背景 1.1 概述 目标检测是计算机视觉的重要分支&#xff0c;主要任务是在给定的图片中精确找到物体所在位置&#xff0c;并标注出物体的类别&#xff0c;即包含了目标定位与目标分类两部分。在计算机视觉领域中的目标跟踪、图像分割、事件检测、场景理解等的任务都以目标…

Java线程几种常用方法详细说明

在Java编程中&#xff0c;多线程编程是一个非常重要的主题。它允许我们同时运行多个任务&#xff0c;提高程序的性能和响应速度。在这篇博客中&#xff0c;我们将介绍一些常用的Java线程方法和构造器&#xff0c;并通过示例代码展示如何使用它们。 Thread提供的常用方法 publi…

SpringBoot与Spring Framework提供的缓存抽象

目录 缓存 项目总结 新建一个SpringBoot项目 pom.xml application.properties CacheConfig Book BookRepository接口 BookService服务类 BookController控制器 SpringbootCacheApplication启动类 启动项目&#xff0c;使用Postman测试 参考博文&#xff1a; 1、使用…

llvm 3.5 源码分析 clang for x86 001 之搭环境

0&#xff0c;目标 编译 针对x86 的&#xff0c;debug 的 c语言的编译器 1&#xff0c;下载代码 git clone --recursive 。。。llvm-project.git $ cd llvm-project 2&#xff0c;预备代码 llvm 3.5 版本的源代码&#xff0c;早期版本&#xff0c;可能比较小比较容易debug $…

Unity MiniCPM-V 让引擎拥有视觉

Unity MiniCPM-V 让引擎拥有视觉 前言项目Python环境布置Unity场景布置代码编写添加并设置脚本总结 鸣谢AI提示 前言 新发布的MiniCPM-V&#xff0c;忍不住玩一下&#xff0c;可以让之前制作的语音助手拥有一定的视觉能力&#xff08;不是OpenCV不行&#xff0c;而是AI更加符合…

深入理解Java关系运算符,避免常见错误!

哈喽&#xff0c;各位小伙伴们&#xff0c;你们好呀&#xff0c;我是喵手。运营社区&#xff1a;C站/掘金/腾讯云&#xff1b;欢迎大家常来逛逛 今天我要给大家分享一些自己日常学习到的一些知识点&#xff0c;并以文字的形式跟大家一起交流&#xff0c;互相学习&#xff0c;一…

复现CELL文章图片,在线绘制scRNA-seq多个cluster的差异火山图

导读 火山图表示两组间的差异&#xff0c;而在scRNA-seq中&#xff0c;同时会有多个cluster&#xff08;vs其他cluster&#xff09;的差异。如果用常规火山图展示&#xff0c;可能需要绘制十几个图。有没有更高效的展示方法呢&#xff1f;今天给大家带来CELL文章“A Spatiotem…

打造SimPO新算法,微调8B模型超越Claude 3 Opus

前言 大型语言模型&#xff08;LLM&#xff09;近年来取得了巨大进展&#xff0c;但要将其与人类价值观和意图相一致&#xff0c;使其变得有用、诚实和无害&#xff0c;仍然是一个挑战。强化学习从人类反馈中&#xff08;RLHF&#xff09;是一种常用的方法&#xff0c;通过微调…

Charles的安装和web端抓包配置

1.Charles的安装 通过官网下载&#xff1a;https://www.charlesproxy.com/download/&#xff0c;我之前下载的是4.6.2版本&#xff0c;下载成功后点击安装包&#xff0c;点击下一步下一步即可安装成功。 ​​ ​ 安装成功后打开charles页面如下所示。 ​ 2.乱码问题解决 打开…

【C++】STL:栈和队列模拟实现

&#x1f49e;&#x1f49e; 前言 hello hello~ &#xff0c;这里是大耳朵土土垚~&#x1f496;&#x1f496; &#xff0c;欢迎大家点赞&#x1f973;&#x1f973;关注&#x1f4a5;&#x1f4a5;收藏&#x1f339;&#x1f339;&#x1f339; &#x1f4a5;个人主页&#x…

绘画参数配置及使用

绘画参数配置及使用 路径&#xff1a;站点后台-功能-AI绘画 进入参数配置 接口选择&#xff1a;多种接口自主选择&#xff08;需自己准备key&#xff09;&#xff0c;对应接口的key对话和绘画通用 存储空间&#xff1a; 位置在超管后台-存储空间 自主选择存储&#xff08;需…

【数据结构与算法】七大排序算法(下)

【数据结构与算法】七大排序算法(下) &#x1f955;个人主页&#xff1a;开敲&#x1f349; &#x1f525;所属专栏&#xff1a;数据结构与算法&#x1f345; &#x1f33c;文章目录&#x1f33c; 2.3 交换排序 2.3.1 冒泡排序 2.3.2 快速排序 2.3.3 快速排序(非递归) 2.4 归并…

fpga入门 串口定时1秒发送1字节

一、 程序说明 FPGA通过串口定时发送数据&#xff0c;每秒发送1字节&#xff0c;数据不断自增 参考小梅哥教程 二、 uart_tx.v timescale 1ns / 1psmodule uart_tx(input wire sclk,input wire rst_n,output reg uart_tx);parameter …

【Python Cookbook】S01E12 根据字段将记录分组

目录 问题解决方案讨论 问题 如果有一系列的字典或对象实例&#xff0c;我们想根据某个特定的字段来分组迭代数据。 解决方案 假设有如下字典列表&#xff1a; rows [{address: 5412 N CLARK, date: 07/01/2012},{address: 5148 N CLARK, date: 07/04/2012},{address: 580…

W25Q64CV SPI Flash Memory

SPI简介 SPI是一种同步串行通信接口规范&#xff0c;用于短距离通信&#xff0c;主要应用于嵌入式系统。SPI通信由一个主设备和一个或多个从设备组成&#xff0c;其中主设备生成时钟信号并控制通信的开始和结束。 SPI通信的基本组成 四个基本信号 SCK (Serial Clock) - 时钟…

centos7下安装MySQL,Oracle数据库

&#x1f4d1;打牌 &#xff1a; da pai ge的个人主页 &#x1f324;️个人专栏 &#xff1a; da pai ge的博客专栏 ☁️宝剑锋从磨砺出&#xff0c;梅花香自苦寒来 操作系统版本为CentOS 7 使⽤ MySQ…

python数据分析——datetime数据类型2

参考资料&#xff1a;活用pandas库 # 导入pandas库 import pandas as pd # 加载数据集 teslapd.read_csv(r"...\data\tesla_stock_yahoo.csv") # 查看数据 print(tesla.head()) 1、基于日期取数据子集 # 将Date数据列转换为datetime类型 tesla[Date]pd.to_datetime…