我正在尝试使用以下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我害怕。感谢。
答案 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 时使用的默认值提供了em> 选项标志。更多信息可以在grunt.options。