不足之处:最近开始使用 Gulp(从 Grunt 转换),并尝试同时使用 Gulp 的默认监视任务(不是来自 npm 的 gulp-watch)用于 SASS/JS/HTML 和 gulp-nodemon(来自 npm)来重新启动 Express服务器根据更改。运行时gulp watch
,它工作正常;并且在运行gulp server
(对于nodemon)时可以正常工作。但是,同时使用两者(在默认任务的配置中显示如下),手表的东西不起作用。该任务正在运行,并且在 CLI gulp 上显示监视任务的“正在启动”和“已完成”,但文件不会更新。
相关任务配置:
连接javascript:
gulp.task('js:app', function(){
return gulp.src([
pathSource('js/application/modules/**/*.js'),
pathSource('js/application/_main.js')
])
.pipe(concat('application.js'))
.pipe(gulp.dest('./build/assets/js')).on('error', utils.log);
});
Nodemon,重新启动 express 应用程序的更改:
gulp.task('express', function(){
return nodemon({script:'server.js', ext:'js', cwd: __dirname + '/express', legacyWatch: true})
.on('restart', function(){
//gulp.run('watch'); // doesn't work :(
});
});
观察 javascript 的变化,并运行 js:app 进行连接。
gulp.task('watch', function(){
gulp.watch(pathSource('js/application/**/*.js'), ['js:app']);
});
默认任务,同时初始化 gulp watch 和 nodemon:
gulp.task('default', ['watch', 'express']);
如果有人有任何想法,请提前致谢!