每当我对 javascript 文件进行更改时,我都会尝试将grunt-contrib-watch与grunt-express-server一起使用来重新加载我的 express 服务器和浏览器页面。我遇到的问题是页面在服务器准备好之前重新加载,所以我得到“无法在 localhost:3000 建立与服务器的连接”。
这是我的 Gruntfile.js:
module.exports = function(grunt) {
'use strict';
grunt.initConfig({
express: {
dev: {
options: {
script: 'gui-resources/scripts/js/server.js'
}
}
},
watch: {
express: {
files: ['gui-resources/scripts/js/**/*.js'],
tasks: ['express:dev'],
options: {
livereload: true,
spawn: false
}
}
}
});
// Load all grunt tasks declared in package.json
require('load-grunt-tasks')(grunt);
grunt.registerTask('default', ['express:dev', 'watch'])
};
在我的 server.js 文件中,我启动服务器:
var port = 3000;
app.listen(port, function() {
console.log('Listening on port %d', port);
});
我发现了这个类似的问题,但是那里提出的解决方案不适用于我的情况,因为我在服务器启动时记录了一些输出,但无论如何都会出现竞争条件。
更新: 如果我从 watch:express 配置中删除 'spawn: false',一切正常,但 express 在启动时会记录错误:
Error: listen EADDRINUSE
at errnoException (net.js:878:11)
at Server._listen2 (net.js:1016:14)
at listen (net.js:1038:10)
at Server.listen (net.js:1104:5)
at Function.app.listen (/Users/pat/projects/sourcefabric/plugin-liveblog-embed-server/node_modules/express/lib/application.js:533:24)
at /Users/pat/projects/sourcefabric/plugin-liveblog-embed-server/gui-resources/scripts/js/server.js:86:13
at Object.context.execCb (/Users/pat/projects/sourcefabric/plugin-liveblog-embed-server/node_modules/requirejs/bin/r.js:1890:33)
at Object.Module.check (/Users/pat/projects/sourcefabric/plugin-liveblog-embed-server/node_modules/requirejs/bin/r.js:1106:51)
at Object.<anonymous> (/Users/pat/projects/sourcefabric/plugin-liveblog-embed-server/node_modules/requirejs/bin/r.js:1353:34)
at /Users/pat/projects/sourcefabric/plugin-liveblog-embed-server/node_modules/requirejs/bin/r.js:372:23
奇怪的是,尽管服务器和页面正确重新加载错误。
这是我的代码(真正的 Gruntfile 更大,但我删除了与 watch 或 express 无关的部分以使问题更具可读性)。