【问题标题】:"babel-plugin-react-intl" is not working as expected“babel-plugin-react-intl”没有按预期工作
【发布时间】:2019-01-19 20:17:48
【问题描述】:

我使用create-react-app 命令创建了我的反应应用程序。现在我想以印地语和英语提供我的网站。 所以为此我使用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"
}
}

【问题讨论】:

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


    【解决方案1】:

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

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

    【讨论】:

    • 谢谢@Tomas Ehrlich
    • 但它正在创建一个 lib 文件夹。是否有必要创建该文件夹。
    • 不,这只是 babel 编译 src 目录的副作用。要么忽略它,要么立即删除它:NODE_ENV=development babel src --out-dir lib &amp;&amp; rm -r lib
    • 嗨,运行 'npm run extract' 出现错误,NODE_ENV 未被识别为内部或外部命令@Tomas。
    • @DivisionSi 你可能需要跨环境包:npmjs.com/package/cross-env。那么命令是cross-env NODE_ENV=development babel src --out-dir lib
    猜你喜欢
    • 1970-01-01
    • 2023-04-05
    • 1970-01-01
    • 2020-12-10
    • 1970-01-01
    • 2018-07-05
    • 2017-04-04
    • 2021-09-03
    • 1970-01-01
    相关资源
    最近更新 更多