我使用create-react-app命令创建了自己的react应用程序。现在我想用印地语和英语访问我的网站。因此,我使用的是yahoo/react-intl。我还安装了babel-插件-react插件。还添加了.babelrc文件。
我的.babelrc文件看起来像:
{
"presets": ["es2015", "react"],
"plugins": [
[
"react-intl",
{
"messagesDir": "./build/messages/"
}
]
]
}但我不会将js文件中提取的消息发送到./build/messages/。
我不知道我在哪里犯了一个错误。
我的index.js是:
import React from "react";
import ReactDOM from "react-dom";
import { IntlProvider, addLocaleData } from "react-intl";
import hi from "react-intl/locale-data/hi";
import en from "react-intl/locale-data/en";
import registerServiceWorker from "./registerServiceWorker";
import Hello from "./components/Hello";
addLocaleData([...en, ...hi]);
ReactDOM.render(
<IntlProvider locale="hi" messages={/*comming soon*/}>
<Hello />
</IntlProvider>,
document.getElementById("root")
);
registerServiceWorker();我所有的js文件都在components文件夹里。
例如,我的Hello.js组件如下所示:
import React, { Component } from "react";
import { FormattedMessage } from "react-intl";
class Hello extends Component {
render() {
return (
<div>
<h1>
<FormattedMessage id="Hello.heading" defaultMessage="Hello world" />
</h1>
<p>
<FormattedMessage
id="Hello.paragraph"
defaultMessage="This is my world"
/>
</p>
</div>
);
}
}
export default Hello;我的package.json是:
{
"name": "i18n-myexamplae",
"version": "0.1.0",
"private": true,
"dependencies": {
"react": "^16.4.2",
"react-dom": "^16.4.2",
"react-intl": "^2.4.0",
"react-scripts": "1.1.4"
},
"scripts": {
"start": "react-scripts start",
"build": "react-scripts build",
"test": "react-scripts test --env=jsdom",
"eject": "react-scripts eject"
},
"devDependencies": {
"babel-plugin-react-intl": "^2.4.0"
}
}发布于 2018-08-13 08:41:50
这是因为react-scripts不使用您的.babelrc。您要么需要弹出,因为这样就可以编辑.babelrc配置,要么需要手动运行babel。
运行./node_modules/.bin/babel src --out-dir lib并忽略/删除--out-dir中的所有内容。你这么做只是为了提取信息。此外,要使构建保持一致,请将es2018和react预置替换为react-app预设,这是create-react-app使用的预置。
注意:在使用react-app预置时,实际上需要运行NODE_ENV=development ./node_modules/.bin/babel src --out-dir lib,因为react-scripts需要配置NODE_ENV。您可以将它添加到您的package.json中,以使事情变得更简单。
"scripts": {
"extract": "NODE_ENV=development babel src --out-dir lib",
...
},在我编写的i18n库中,我遇到了一个类似的问题,语言。lingui extract命令检查项目是否使用create-react-app,如果使用create-react-app,则自动使用react-app预设来提取消息。
https://stackoverflow.com/questions/51816600
复制相似问题