考虑到这个示例配置(注意,为了保持简短,我省略了依赖项):
module.exports = function(grunt) {
grunt.initConfig({
pkg: grunt.file.readJSON('package.json'),
sass: {
dev: {
files: {
'style.css': 'custom.scss'
}
},
},
watch: {
options: {
livereload: true
},
css: {
files: ['css/sass/**/*.scss'] ,
tasks: ['sass:dev']
},
js:{
files: ['js/**/*.js']
},
html:{
files: ['templates/**/*.html']
},
dontRun:{
files: ['/randomdir/*'],
tasks:['randomtask']
}
}
});
grunt.registerTask('default', ['watch']);
};如何启动监视和执行css, js and html (而不是dontRun )的手表?
我试过:
grunt.registerTask('default', ['watch:css:js:html']);
grunt.registerTask('default', ['watch:css','watch:js','watch:html']);但这两个都只是执行第一个手表,第二个和第三个只是没有启动。
发布于 2014-03-05 05:55:34
这是因为Grunt只能在一个系列中运行任务。因此,监视任务只能运行一个目标或所有目标。
但是,您可以使用动态别名任务来解决这一限制:
grunt.registerTask('watchweb', function() {
// Remove the targets you dont want
grunt.config('watch.dontRun', null);
// Then run the watch task after this task is done
grunt.task.run('watch');
});使用grunt watchweb运行。
或者使用任何配置的更健壮和通用的解决方案是:
// Run with: grunt switchwatch:target1:target2 to only watch those targets
grunt.registerTask('switchwatch', function() {
var targets = Array.prototype.slice.call(arguments, 0);
Object.keys(grunt.config('watch')).filter(function(target) {
return !(grunt.util._.indexOf(targets, target) !== -1);
}).forEach(function(target) {
grunt.log.writeln('Ignoring ' + target + '...');
grunt.config(['watch', target], {files: []});
});
grunt.task.run('watch');
});https://stackoverflow.com/questions/22186476
复制相似问题