我一直在努力寻找一个看似简单的问题。我正在设置一个新的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)。我觉得让这个改变打破了一些我现在理所当然的参考。有什么想法在哪里寻找我的错误?
答案 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
配置,我不会遇到这个问题。快乐的编码!