【发布时间】:2017-08-17 14:33:41
【问题描述】:
我正在尝试对我的 CSS 使用 Webpack 热模块替换。
我运行 PHP 内置服务器 (php -S localhost:8000 -t .) 来加载以下 index.php 文件,该文件位于我的项目的根目录中:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Test webpack</title>
</head>
<body>
<h1>Hello world</h1>
<script src="http://localhost:8080/app.js"></script>
</body>
</html>
然后我想使用webpack-dev-server 及其热模块替换功能来查看我每次保存 CSS 文件时的 CSS 更改。
这是我的webpack.config.js:
const path = require("path");
module.exports = {
entry: {
app: "./src/app.js"
},
output: {
path: path.join(__dirname, "assets"),
filename: "[name].js"
},
module: {
rules: [
{
test: /\.css$/,
use: [
{
loader: "style-loader"
},
{
loader: "css-loader"
}
]
}
]
}
};
这是我的./src/app.js:
import "./app.css";
这是我的./src/app.css:
body {
background-color: #fff;
}
我正在通过输入 webpack-dev-server 开始:./node_modules/.bin/webpack-dev-server --hot。
问题在于,它总是重新加载整个页面,而不是热重新加载 CSS。
这是我浏览器控制台中打印的内容:
Navigated to http://localhost:8000/
[HMR] Waiting for update signal from WDS...
[WDS] Hot Module Replacement enabled.
[WDS] App updated. Recompiling...
[WDS] App hot update...
[HMR] Checking for updates on the server...
GET http://localhost:8000/8f2d15bbf1ed4e8f7e63.hot-update.json 404 (Not Found)
[HMR] Cannot find update. Need to do a full reload!
[HMR] (Probably because of restarting the webpack-dev-server)
根据这些日志,问题是它在localhost:8000/8f2d15bbf1ed4e8f7e63.hot-update.json上搜索更新信息,显然找不到,因为它是我的PHP服务器(8000端口)。但我不知道为什么webpack-dev-server 会尝试访问localhost:8000,因为它默认在localhost:8080 上运行并且我没有覆盖任何内容。
我正在运行 webpack@3.5.5 和 webpack-dev-server@2.7.1。
有没有人遇到同样的问题并找到了解决方案?
谢谢。
【问题讨论】:
标签: webpack webpack-dev-server webpack-hmr