我正在设置 react-i18n-next 钩子来翻译我的应用程序,我遵循了 react-i18n-next 使用的示例,但它引发了如下错误:
i18next::translator: missingKey
en-US
translation
App.js
import React, { Component, Suspense } from "react";
import { useTranslation, withTranslation, Trans } from "react-i18next";
// use hoc for class based components
class LegacyWelcomeClass extends Component {
render() {
const { t } = this.props;
return <h2>{t("title")}</h2>;
}
}
const Welcome = withTranslation()(LegacyWelcomeClass);
// Component using the Trans component
function MyComponent() {
return <Trans i18nKey="description.part1" />;
}
// page uses the hook
function Page() {
const { t, i18n } = useTranslation();
const changeLanguage = lng => {
i18n.changeLanguage(lng);
};
return (
<div className="App">
<div className="App-header">
<Welcome />
<button type="button" onClick={() => changeLanguage("de")}>
de
</button>
<button type="button" onClick={() => changeLanguage("en")}>
en
</button>
</div>
<div className="App-intro">
<MyComponent />
</div>
<div>{t("description.part2")}</div>
</div>
);
}
// loading component for suspense fallback
const Loader = () => (
<div className="App">
<div>loading...</div>
</div>
);
// here app catches the suspense from page in case translations are not yet loaded
export default function App() {
return (
<Suspense fallback={<Loader />}>
<Page />
</Suspense>
);
}
i18n.js
import i18n from "i18next";
import Backend from "i18next-http-backend";
import LanguageDetector from "i18next-browser-languagedetector";
import { initReactI18next } from "react-i18next";
i18n
.use(Backend)
.use(LanguageDetector)
.use(initReactI18next)
.init({
fallbackLng: "en",
debug: true,
interpolation: {
escapeValue: false // not needed for react as it escapes by default
}
});
export default i18n;
index.js
import React from "react";
import ReactDOM from "react-dom";
import App from "./App";
// import i18n (needs to be bundled ;))
import "./i18n";
ReactDOM.render(<App />, document.getElementById("root"));
示例代码可用 here 并且我不知道我缺少什么,最好获得一些基本的工作示例和任何关于这真的很有帮助的帮助。
我的要求是,我需要将我的应用程序翻译成其他语言,例如从 en 到 fr,我拥有的唯一上下文是 en 文件。
答案 0 :(得分:1)
在上面的代码中有一些你需要做的事情
假设translationEN.json -
{
"title": "Title",
"Welcome to React": "Welcome to React and react-i18next",
"description": {
"part2": "some description"
}
}
和translationDE.json -
{
"title": "DE ***** Title",
"Welcome to React": "DE **** Welcome to React and react-i18next",
"description": {
"part2": "DE **** some description"
}
}
在 i18n.js 中导入上述文件并在 i18n init 中添加 resources 和 lng
import translationEN from "../src/translationEN.json";
import translationDE from "../src/translationDE.json";
const resources = {
en: {
translation: translationEN
},
de: {
translation: translationDE
}
};
i18n
.use(Backend)
.use(LanguageDetector)
.use(initReactI18next)
.init({
resources,
lng: "en",
解决方案已添加here