Express和Webpack问题:“未捕获的SyntaxError:意外的令牌<”

时间:2019-09-25 01:38:24

标签: javascript node.js reactjs express webpack

我无法测试使用WebPack开发的react网页。我正在尝试运行快速服务器,但始终收到带有控制台消息Uncaught SyntaxError: Unexpected token <的空白localhost页面。网页似乎可以找到我的index.html文件,该文件又将其指向由webpack创建的bundle.js文件,但是由于某种原因,我的bundle.js文件显示为空,我相信吗?这是我第一次使用webpack,所以我还是比较陌生。我将在目录结构,webpack.config.js文件,server.js文件和index.html文件的下面发布图片/摘要。在此先非常感谢您,我还是webpack的新手,这是我第一次尝试实际使用express和webpack进行部署。 顺便说一句,我的React应用程序在使用webpack-dev-server时运行良好,并非如此。

我的目录结构

directory-structure

我的webpack.config.js文件

const webpack = require('webpack');
const MomentLocalesPlugin = require('moment-locales-webpack-plugin');

module.exports = {
  entry: ['babel-polyfill','./src/index.js'],
  module: {
    rules: [
      {
        test: /\.(js|jsx)$/,
        exclude: /node_modules/,
        use: ['babel-loader']
      },
        {
            test: /\.(png|jp(e*)g|svg)$/,  
            use: [{
                loader: 'url-loader',
                options: { 
                    limit: 8000, // Convert images < 8kb to base64 strings
                    name: 'images/[hash]-[name].[ext]'
                } 
            }]
        },
        {
          test: /\.css$/,
          use: ['style-loader', 'css-loader']
        }
    ]
  },
  resolve: {
    extensions: ['*', '.js', '.jsx']
  },
  output: {
    path: __dirname + '/dist',
    publicPath: '/',
    filename: 'bundle.js'
  },
  plugins: [
    new webpack.HotModuleReplacementPlugin(),
    new MomentLocalesPlugin()
  ],
  devServer: {
    contentBase: './dist',
    hot: true
  }
};

我的server.js文件

const express = require('express');
const path = require('path');
const port = process.env.PORT || 8080;
const app = express();


app.use(express.static(__dirname));


app.get('*', (req, res) => {
    res.sendFile(path.resolve(__dirname, 'index.html'));
});

app.listen(port, () => {
    console.log('listening on port ' + port);
    console.log(__dirname);
});

我的index.html文件

<!DOCTYPE html>
<html>
  <head>
    <title>Hello Webpack</title>
  </head>
  <body>
    <div id='app'></div>
    <script src="/bundle.js"></script>
  </body>
</html>

开发工具网络结果

chrome dev tools network results

编辑

我的server.js文件现已编辑,如下所示。我已经克服了第一个错误,但是现在找不到我的bundle.js文件了吗?我将从下面的git bash终端发布日志记录错误图片。 Chrome开发工具控制台也给我一个404错误。

const express = require('express');
const path = require('path');
const port = process.env.PORT || 8080;
const app = express();


app.use(express.static(__dirname));

app.get('*', (req, res) => {
    if (req.path.endsWith('bundle.js')) {
        res.sendFile(path.resolve(__dirname, 'bundle.js'));
    } else {
        res.sendFile(path.resolve(__dirname, 'index.html'));
    }
});




/*
app.get('*', (req, res) => {
    res.sendFile(path.resolve(__dirname, 'index.html'));
});
*/

app.listen(port, () => {
    console.log('listening on port ' + port);
    console.log(__dirname);
});

logging error

非常感谢!

1 个答案:

答案 0 :(得分:0)

您的server.js正在为所有请求提供index.html

这意味着当浏览器请求bundle.js时,server.js再次返回index.html。该错误来自浏览器试图将接收到的HTML解析为JavaScript代码。

修复

您的bundle.js可能不在index.html的同一文件夹中,否则express会为您服务(因为行app.use(express.static(__dirname));)。

因此,请仔细检查bundle.js的路径。应该位于__dirname(即${__dirname}/bundle.js)。

在您发布的图片中,there is no bundle.js in the dist/ folder位于${__dirname}/bundle.jsindex.html的位置。

生成bundle.js

您必须生成捆绑软件。您说from the comments,您的server.js是:

scripts

要生成捆绑包,则应添加一个"scripts": { "start": "webpack-dev-server --config ./webpack.config.js --mode development", "test": "echo \"Error: no test specified\" && exit 1" }, 脚本并执行它。

将此添加到您的package.json build

scripts

现在它是这样的:

"build": "webpack --mode production",

现在运行"scripts": { "build": "webpack --mode production", "start": "webpack-dev-server --config ./webpack.config.js --mode development", "test": "echo \"Error: no test specified\" && exit 1" }, (或npm run build)。 yarn build现在应该位于build.js文件夹中。

请记住,如果您曾经部署过它,则在提供服务时应同时将dist/index.html放在同一个文件夹中。