“ babel-plugin-react-intl”无法正常工作

时间:2018-08-13 06:49:46

标签: reactjs react-intl babel-plugin-react-intl

我已经使用create-react-app命令创建了我的react应用。现在,我想以印地文和英文提供我的网站。 因此,我正在使用yahoo/react-intl。我还安装了babel-plugin-react-intl插件。还添加了.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"
}
}

1 个答案:

答案 0 :(得分:3)

这是因为react-scripts不使用您的.babelrc。您可能需要退出,因为这样便可以编辑.babelrc的配置,或者您需要手动运行babel。

运行./node_modules/.bin/babel src --out-dir lib,然后忽略/删除--out-dir中的所有内容。您这样做只是为了提取消息。另外,要使构建保持一致,请用es2018使用的react预设替换react-appcreate-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中遇到了类似的问题。 lingui extract命令正在检查项目是否使用create-react-app,如果使用,则自动使用预设的react-app提取消息。