dev_prod_switch没有获取命令行变量

时间:2017-01-16 09:42:38

标签: javascript node.js gruntjs

我正在尝试使用以下grunt插件来使我能够使用包含链接到我的生成版本的压缩文件,并为我的开发版本解压缩。

https://www.npmjs.com/package/grunt-dev-prod-switch

以下是我的Gruntfile的缩写版本:     ...     grunt.loadNpmTasks('咕噜-DEV-PROD开关&#39);

    // Project configuration.
    grunt.initConfig({
    ...
    dev_prod_switch: {
        options: {
            environment: 'dev',
            env_char: '#',
            env_block_dev: 'env:dev',
            env_block_prod: 'env:prod'
        },
        dynamic_mappings: {
            files: [{
                expand: true,
                cwd: 'dist',
                src: ['*.html', 'js/includes.js', 'js/includes.min.js'],
                dest: 'dist'
            }]
        }
    },
    ....
    // Full distribution task.
    grunt.registerTask('dev', ['...', '...', 'dev_prod_switch']);
    grunt.registerTask('prod', ['...', '...', '...', 'dev_prod_switch']);
});

在我使用的HTML文件中:                                      

在我的includes.js文件中:

var path;
/* env:dev */
    path = "js/pageScripts/dashboard.js";
/* env:dev:end */
/* env:prod */
    path = "js/pageScripts/dashboard.min.js"
/* env:prod:end */
plenty_admin.REST.loadScript(path, function(){
     ....
});

我使用以下命令在命令行触发我的构建:

grunt prod --env=prod

grunt dev --env=dev

这对" dynamic_mappings"中定义的文件的方式没有影响。处理,但如果我设置:

environment: 'prod',

在编译之前,使用我在html / js文件中设置的prod条件注释正确处理文件。

完美的世界就是简单地运行:

grunt dev

grunt prod

并查看按预期处理的输出文件,但如果无法避免将环境变量添加到最后则不是问题。

grunt prod --env=prod

grunt dev --env=dev

任何帮助表示赞赏,并且乐意在必要时添加更多详细信息 - 我是一个节点/咕噜noob我害怕。感谢。

1 个答案:

答案 0 :(得分:1)

根据docs ...

中的示例

更改options对象,如下所示:

options: {
    environment: grunt.option('env') || 'dev', // <-- Change value to this !
    env_char: '#',
    env_block_dev: 'env:dev',
    env_block_prod: 'env:prod'
}

注意:这会根据CLI提供的标志设置选项。当该值设置为'dev',如上面的代码所示)时,这意味着dev将是 no 选项标志。更多信息可以在grunt.options

中找到