如何将动态配置传递给gruntfile.js



我已经将grunt任务写给了ES5。以下是我的 gruntfile.js 文件

module.exports = function (grunt)
{
    require("load-grunt-tasks")(grunt);
    grunt.initConfig({
        "babel": {
            options: {
                presets: ['es2015']
            },
            dist: {
                files: [{
                  expand: true,
                  cwd: '/Users/pankajmeshram/Documents/IVWorkSpace/enfresh/resources/modules',
                  src: ['**/*.es6'],
                  dest: '/Users/pankajmeshram/Documents/IVWorkSpace/enfresh/resources/modules',
                  ext: '.js'
              }]
            }
        }
    });
    grunt.registerTask("default", ["babel"]);
};

在此文件中,我想动态通过CWD和DEST选项,以便我可以将其用于不同的项目,以及我们对所有项目都有共同的构建。

如果之前有人从事此工作,您可以为此任务建议一些方法或任何其他解决方案。

module.exports = function(grunt) {
    require("load-grunt-tasks")(grunt);
    grunt.initConfig({
        "babel": {
            options: {
                presets: ['es2015']
            },
            dist: {
                files: [{
                    expand: true,
                    cwd: "<%= cwd %>",
                    src: ['**/*.es6'],
                    dest: "<%= dest %>",
                    ext: '.js'
                }]
            }
        }
    });
    grunt.registerTask("dynamicConfigs", "Set Dynamic Configs", function (argName, argValue) {
        grunt.config.set(argName, argValue);
    });
    grunt.registerTask("default", ["dynamicConfigs:cwd:/Users/vineethgn/Documents/IVWorkSpace/enfresh/resources/modules", "dynamicConfigs:dest:/Users/vineethgn/Documents/IVWorkSpace/enfresh/resources/modules", "babel"]);
};

您可以将这些属性定义为模板,然后在调用babel任务之前,调用新创建的dynamicConfigs任务。在DynamicConfig中,您基本上是在grunt.config中设置键值对。确保使用您要在上面的示例代码中设置的参数调用dynamicConfigs任务。

最新更新