ReactDOM RSS renderToString生产错误

Jas*_*onV 5 reactjs webpack react-hot-loader ssr

我为react16创建了新的样板.

https://github.com/jasonvillalon/react16-boilerplate

它在开发中运行时使用:

npm start
npm start:webpack
Run Code Online (Sandbox Code Playgroud)

但是在生产中运行时会在renderToString上抛出错误

NODE_ENV=production npm start
Run Code Online (Sandbox Code Playgroud)

webpack成功而没有错误,但在呈现页面时出现错误:

ERROR: TypeError: Cannot set property 'getCurrentStack' of undefined
at setCurrentDebugStack (webpack:///./node_modules/react-dom/cjs/react-dom-server.node.development.js?:1816:48)
at ReactDOMServerRenderer.read (webpack:///./node_modules/react-dom/cjs/react-dom-server.node.development.js?:2225:13)
at renderToString (webpack:///./node_modules/react-dom/cjs/react-dom-server.node.development.js?:2494:29)
at _callee$ (webpack:///./src/server.jsx?:66:49)
at tryCatch (/Users/jasonvillalon/Documents/fun-projects/from-scratch/node_modules/babel-polyfill/node_modules/regenerator-runtime/runtime.js:65:40)
at Generator.invoke [as _invoke] (/Users/jasonvillalon/Documents/fun-projects/from-scratch/node_modules/babel-polyfill/node_modules/regenerator-runtime/runtime.js:303:22)
at Generator.prototype.(anonymous function) [as next] (/Users/jasonvillalon/Documents/fun-projects/from-scratch/node_modules/babel-polyfill/node_modules/regenerator-runtime/runtime.js:117:21)
at step (webpack:///./src/server.jsx?:27:191)
at eval (webpack:///./src/server.jsx?:27:437)
at new Promise (<anonymous>)
Run Code Online (Sandbox Code Playgroud)

任何人都知道发生了什么事?

最诚挚的问候,杰森

Rya*_*ton 3

问题是,在 Webpack 中,您设置了以下内容:

let config = {
  mode: "development",
....
Run Code Online (Sandbox Code Playgroud)

但您可以在 Winblows / DOS 命令行上设置:

set NODE_ENV=production
Run Code Online (Sandbox Code Playgroud)

或者在 Linux 上你已经设置了

export NODE_ENV=production
Run Code Online (Sandbox Code Playgroud)

或者可能在您的 webpack.config.js 中设置:

let config = {
  ...

  new webpack.DefinePlugin({
    "process.env": {
      NODE_ENV: JSON.stringify("production")
    }
  })
Run Code Online (Sandbox Code Playgroud)

要解决此问题,您需要修复顶部部分:

let config = {
  mode: "production",
....
Run Code Online (Sandbox Code Playgroud)

或取消设置 NODE_ENV 环境变量。

上述评论归功于@Jordan M Alperin。