首先 - 我是webpack的新手。我是browserify的忠实粉丝,但决定将我的一个新项目切换到webpack,以便尝试每个人都在谈论的内容。
其次 - 文档有点难以阅读(页面设计,内容顺序等),没有很好的样板来将现有服务器与webpack-dev-server集成。我试图自己做,但收到一个恼人的错误..
webpack-dev-server --hot --inline --progress --colors
70% 1/1 build modules
TypeError: Object /Users/me/github/app-webpack/node_modules/webpack-dev-server/client/index.js?http://localhost:8080,webpack/hot/dev-server,webpack/hot/dev-server has no method 'replace'
at Tapable.<anonymous> (/Users/me/github/app-webpack/node_modules/webpack/lib/NormalModuleFactory.js:42:26)
webpack.config.js
的样子:
'use strict';
var webpack = require('webpack');
module.exports = {
entry: [
'webpack/hot/dev-server',
'./src/app.js'
],
output: {
path: __dirname + '/public/build/',
filename: 'bundle.js',
publicPath: '/build/'
},
resolve: {
extensions: ['', '.js', '.jsx']
},
module: {
loaders: [
{
test: /\.(js|jsx)$/,
exclude: /node_modules/,
loaders: ['babel-loader?experimental']
}
]
},
plugins: [
new webpack.NoErrorsPlugin()
]
};
现有服务器只提供base.html
:
const env = process.env.NODE_ENV || 'development';
const port = process.env.NODE_PORT || 1995;
var http = require('http');
var path = require('path');
var express = require('express');
var nunjucks = require('nunjucks');
var address = require('network-address');
var app = express();
nunjucks.configure('layouts', {
autoescape: true,
express: app
});
app.set('port', port);
app.use(express.static(path.join(__dirname, 'public')));
app.get('*', (req, res) => {
res.render('base.html', {
// returning js file to template
mainJS: 'http://localhost:8080/build/bundle.js'
});
});
http.createServer(app).listen(app.get('port'), function () {
console.info('Demo app is listening on "%s:%s" env="%s"', address(), app.get('port'), env);
});
而base.html
只需插入脚本:
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>App Webpack</title>
</head>
<body>
<div id="app"></div>
<script src="{{mainJS}}"></script>
</body>
</html>