我按照grunt.option页面上的说明为不同的环境/目标创建不同的配置,例如在我的gruntfile中进行开发、登台和生产。然而,这样做后,我发现我的任务默默地失败了。
我把这个问题简化为一个很简单的例子。以下gruntfile无法生成文件:
module.exports = function (grunt) {
grunt.initConfig({
pkg: grunt.file.readJSON('package.json'),
less: {
dev: {
options: {
compress: true
},
build: {
src: ['src/css/test.less'],
dest: 'build/css/test.css'
}
}
}
});
grunt.loadNpmTasks('grunt-contrib-less');
grunt.registerTask('default', ['less:dev']);
};
我的终端输出如下:
$ grunt
Running "less:dev" (less) task
Done, without errors.
但是,如果我使用以下gruntfile,则生成输出与预期一致:
module.exports = function (grunt) {
grunt.initConfig({
pkg: grunt.file.readJSON('package.json'),
less: {
options: {
compress: true
},
build: {
src: ['src/css/test.less'],
dest: 'build/css/test.css'
}
}
});
grunt.loadNpmTasks('grunt-contrib-less');
grunt.registerTask('default', ['less']);
};
此gruntfile的终端输出反映生成的文件:
$ grunt
Running "less:build" (less) task
File build/css/test.css created.
Done, without errors.
我在第一个文件里做错了什么?关于这次会议我遗漏了什么?
最佳答案
你的第一个gruntfile-如果你想要每个目标选项,你需要指定files
对象。所以你的代码应该是这样的:
less: {
dev: {
files: {
"build/css/test.css": "src/css/test.less"
}
},
production: {
options: {
compress: true
},
files: {
"build/css/test.css": "src/css/test.less"
}
},
}
基本上在第一个gruntfile
build
中是一个未知对象。您的目标名为dev
,grunt-contrib-less
没有名为build
的选项,因此grunt不知道在哪里写文件。您的第二个gruntfile可以工作,因为您将选项设置为全局选项。如果需要每个目标选项,请使用以上代码。关于node.js - Gruntjs目标我在做什么错?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/18998856/