[英]node.js: include external grunt configuration
我在頂級目錄中有一個grunt文件,我想包含子文件夾中的配置設置。 用咕嚕聲有沒有干凈的方法呢?
將它們放在JSON文件中並使用grunt.file.readJSON導入它們。
例:
module.exports = function (grunt) {
grunt.initConfig({
settings: grunt.file.readJSON('subfolder/settings.json'),
settings2: grunt.file.readJSON('subfolder2/settings.json'),
task: {
target: {
files: {
'dest': '<%- settings.path %>',
'dest': '<%- settings2.path %>'
}
}
}
});
};
作為替代方案,您可以使用require
。 具有不同環境的此設置的示例,具有“concat”和“uglify”組件。
結構體:
// root
Gruntfile.js
config/
env1.js
env2.js
src/
file1.js
file2.js
...
dest/
env1.js
env1.min.js
env2.js
env2.min.js
文件:
// Gruntfile.js ...
// ____________________>
var config = {
'env1' : require('./config/env1'),
'env2' : require('./config/env2')
};
module.exports = function (grunt) {
grunt.initConfig({
concat: {
env1: {
src: config.env1, // ^config
dest: 'dest/env1.js'
},
env2: {
src: config.env2, // ^config
dest: 'dest/env2.js'
}
},
uglify: {
my_target: {
files: {
'dest/env1.min.js' : ['dest/env1.js'],
'dest/env2.min.js' : ['dest/env2.js']
}
}
}
});
grunt.loadNpmTasks('grunt-contrib-concat');
grunt.loadNpmTasks('grunt-contrib-uglify');
grunt.registerTask('default', ['concat', 'uglify']);
};
// config/env1.js ...
// ____________________>
module.exports = [
// files...
'src/file1.js',
'src/file2.js',
'src/file3.js'
];
// config/env2.js ...
// ____________________>
module.exports = [
// files...
'src/file4.js',
'src/file5.js',
'src/file6.js'
];
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.