1

每当我对 javascript 文件进行更改时,我都会尝试将grunt-contrib-watchgrunt-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 无关的部分以使问题更具可读性)。

4

1 回答 1

0

我认为您应该能够使用选项debounceDelay等待livereload更长的时间,直到您的服务器准备好:

watch: {
    express: {
        files: ['gui-resources/scripts/js/**/*.js'],
        tasks: ['express:dev'],
        options: {
            livereload: true,
            spawn: false,
            debounceDelay: 1000 // in milliseconds
        }
    }
}
于 2014-02-13T21:53:21.113 回答