这是我的Grunfile监视任务:
watch: {
jsFiles: {
files: ['www/js/*.js','!www/js/*.min.js'],
tasks: ['jshint','<%= pkg.jsTask %>'],
options: {
event: ['added', 'changed'],
spawn: false
}
},
cssFiles : {
files : ['<%= pkg.cssTask === "less" ? "www/less/*.less" : "www/css/*.css" %>'],
tasks : ['<%= pkg.cssTask %>'],
options: {
event: ['added', 'changed'],
spawn: false
}
},
pageFiles : {
files: ['www/**.php','www/**.html'],
tasks: ['<%= "uglify:some" === pkg.jsTask ? "dom_munger:whenSomeJs" : "dom_munger:whenAllInOneJs" %>','undoDomMungerQuoteShit'],
options: {
event: ['added', 'changed'],
spawn: false
}
},
otherFiles : {
files: ['www/**','!www/**.php','!www/**.html','!www/js/*.js','!www/css/*.less','!www/css/*.css'],
tasks: ['copy:regularFiles'],
options: {
event: ['added', 'changed'],
spawn: false
}
},
allFiles : {
files: ['www/**'],
options: {
event: ['deleted'],
spawn: false
}
},
ftpFiles : {
files: ['build/**'],
tasks: ['copy:ftp'],
options: {
event: ['added', 'changed'],
spawn: false
}
},
ftpDelete : {
files: ['build/**'],
options: {
event: ['deleted'],
spawn: false
}
}
}
所有子任务都将处理后的文件放在“build”文件夹中。所有子任务,但其中一个正在按预期工作:“ftpFiles”
此子任务在“build”文件夹中查找更改。当我手动更新某个“build”文件夹文件时,“ftpFiles”可以正常工作。但是当更改的文件被某些其他子任务更新时,“ftpFiles”不会触发。
我该如何解决?
答案 0 :(得分:2)
看起来您需要并发观察者才能运行。 您可以使用grunt-concurrent或grunt-focus来实现这一目标。
按照下面的 grunt-concurrent 示例:
concurrent: {
options: {
logConcurrentOutput: true
},
dev: {
tasks: ["watch:js", "watch:ftp"]
}
}
grunt.registerTask("watch-dev", ["concurrent:dev"]);