
linguijs 提供了多种方式来处理国际化消息,主要包括 <trans> 组件和 t / msg 宏。它们在编译时都会将文本提取到翻译目录中,但在运行时处理方式有所不同:
当我们在 React 组件中将 t 宏的返回值直接作为属性(例如 data={thello react})传递时,如果接收组件没有显式地获取 i18n 上下文并调用 _() 方法,那么它将无法正确地显示翻译后的内容,因为它接收到的是一个 MessageDescriptor 对象,而不是一个字符串。
为了在 React 函数组件中正确地使用 t 或 msg 宏返回的 MessageDescriptor 进行翻译,我们需要遵循以下步骤:
下面是根据问题描述和解决方案修改后的代码示例:
在此处,我们将 t 宏替换为 msg 宏,以明确我们正在定义一个消息描述符,而不是期望立即得到翻译字符串。这个描述符将被传递给 DataComponent。
import React from "react";
import ReactDOM from "react-dom/client";
import reportWebVitals from "./reportWebVitals";
import { StoreProvider } from "./components/store-provider";
import createStore from "./store";
import { LanguageProvider } from "./components/language-provider";
import { LangSwitcher } from "./components/lang-switcher";
import { DataComponent } from "./components/DataComponent";
import { Trans, msg } from "@lingui/macro"; // 导入 msg 宏
const store = createStore();
const root = ReactDOM.createRoot(
document.getElementById("root") as HTMLElement
);
root.render(
<React.StrictMode>
<StoreProvider store={store}>
<LanguageProvider>
<LangSwitcher />
<p>
<Trans>hello world</Trans>
</p>
{/* 使用 msg 宏定义消息,并将其作为 MessageDescriptor 传递 */}
<DataComponent data={msg`hello react`} />
</LanguageProvider>
</StoreProvider>
</React.StrictMode>
);
reportWebVitals();在 DataComponent 中,我们使用 useLingui 钩子获取 i18n 实例,然后调用 i18n._() 方法来翻译传入的 MessageDescriptor。
import { MessageDescriptor } from "@lingui/core"; // 导入 MessageDescriptor 类型
import { useLingui } from "@lingui/react"; // 导入 useLingui 钩子
type props = {
data: MessageDescriptor; // 明确指定 data 属性的类型为 MessageDescriptor
};
export const DataComponent: React.FC<props> = ({ data }) => {
const { i18n } = useLingui(); // 使用 useLingui 钩子获取 i18n 实例
return <p>{i18n._(data)}</p>; // 使用 i18n._() 方法翻译 MessageDescriptor
};"extract": "lingui extract --clean", "compile": "lingui compile --strict"
LinguiJS 的 t 宏和 msg 宏在 React 应用中用于定义可翻译消息,它们在运行时返回 MessageDescriptor 对象。为了在 React 组件中将这些描述符转换为实际的翻译字符串,必须利用 useLingui 钩子获取 i18n 实例,并调用其 _() 方法。理解这一核心机制是正确使用 LinguiJS 进行 React 应用国际化的关键。通过遵循上述最佳实践,您可以确保应用程序中的所有可翻译内容都能得到正确的处理和显示。
以上就是LinguiJS t 宏在 React 组件中不生效的解决方案与最佳实践的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号