4

我在顶级目录中有一个 grunt 文件,我想包含子文件夹中的配置设置。有没有一种干净的方法可以用 grunt 做到这一点?

4

2 回答 2

15

将它们放入 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 %>'
                }
            }
        }
    });
};
于 2013-01-14T21:49:37.190 回答
1

作为替代方案,您可以使用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'
];
于 2017-01-28T12:16:14.213 回答