将index.html移动到公用文件夹时设置新的React项目时出错

时间:2017-05-26 06:02:37

标签: javascript reactjs webpack serverside-rendering

我一直在努力寻找一个看似简单的问题。我正在设置一个新的React项目并构建我的文件夹。我有这样的事情:

/node_modules
/public
   |__ 0.bundle.js
   |__ bundle.js
   // the goal is to move index.html in this folder
/src
   |__components
   App.js
   ClientApp.js
.babelrc
.eslintrc
index.html
package.json
server.js
webpack.config.js
yarn.lock

现在我的索引文件看起来像这样:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>React Test</title>
</head>
<body>
  <div id="app"><%= body %></div>
  <script src="/public/bundle.js"></script>
</body>
</html>

我的server.js是:

require('babel-register')

const express = require('express')
const React = require('react')
const ReactDOMServer = require('react-dom/server')
const ReactRouter = require('react-router-dom')
const StaticRouter = ReactRouter.StaticRouter
const _ = require('lodash')
const fs = require('fs')
const PORT = 5000
const baseTemplate = fs.readFileSync('./index.html')
const template = _.template(baseTemplate)
const App = require('./src/App').default

const server = express()

server.use('/public', express.static('./public'))

server.use((req, res) => {
  const body = ReactDOMServer.renderToString(
    React.createElement(StaticRouter, {location: req.url, context: {}},
      React.createElement(App)
    )
  )

  res.write(template({body: body}))
  res.end()
})

console.log('listening on port', PORT)
server.listen(PORT)

一切都像魅力(服务器和客户端呈现),现在我想进行一个简单的更改并将index.html文件移到/public文件夹中。我更新了指向它的相应文件以及index正在查找bundle.js.文件的位置。所以我的新index.html是:

...
<body>
  <div id="app"><%= body %></div>
  <!-- <script src="/public/bundle.js"></script> I actually removed this -->
  <script src="bundle.js"></script>
</body>
...

我的服务器更新为:

...
const baseTemplate = fs.readFileSync('./public/index.html')
const template = _.template(baseTemplate)
const App = require('./src/App').default

...
server.listen(PORT)

使用此设置客户端渲染仍然有效,但服务器端渲染会引发错误:

Uncaught SyntaxError: Unexpected token <

我花了一段时间才找出问题所在。并且显然server.js能够在我将文件移动到public文件夹后检测到该文件(如果我检查HTML它实际上是在那里),但是加载实际文件时遇到了麻烦app(意为js)。我觉得让这个改变打破了一些我现在理所当然的参考。有什么想法在哪里寻找我的错误?

1 个答案:

答案 0 :(得分:2)

有趣的是,我发现了问题所在,我的配置也遇到了问题webpack,我正在跳过。我没有根据我的新配置更新output路径。

output: {
  path: path.join(__dirname, '/public'),
  filename: 'bundle.js',
  // publicPath: '/public/' --> This was causing the error
  publicPath: '/js/'
},

导致错误的原因是因为如果index.html放在主文件夹中(原来是这样),那么它需要在public内查找包。将文件夹作为使用webpack指定的旧publicPath配置。移动index.html文件夹内的public后,捆绑包现在与index.html文件位于同一文件夹中,因此我们应该引用的路径现在是index自己的文件夹。这会转换为上面代码段中指定的新publicPath

我希望这可以帮助别人,我应该更加了解我的webpack配置,我不会遇到这个问题。快乐的编码!