有没有办法扩展angular.json中的配置? [英] Is there a way to extend configurations in angular.json?
问题描述
在构建Angular 6应用程序时,我需要一次指定两件事:
While building my Angular 6 application, I need to specify 2 things at once:
- 如果是生产或开发版本
- 我正在使用的语言环境
我的angular.json
中有:
"build": {
...
"configurations": {
"production": {
"fileReplacements": [
{
"replace": "src/environments/environment.ts",
"with": "src/environments/environment.prod.ts"
}
],
"optimization": true,
"outputHashing": "all",
"sourceMap": false,
"extractCss": true,
"namedChunks": false,
"aot": true,
"extractLicenses": true,
"vendorChunk": false,
"buildOptimizer": true
},
"pl": {
"fileReplacements": [
{
"replace": "src/assets/i18n/translations.json",
"with": "src/assets/i18n/pl.json"
}
]
},
"en": {
"fileReplacements": [
{
"replace": "src/assets/i18n/translations.json",
"with": "src/assets/i18n/en.json"
}
]
}
}
}
但是当我执行ng build --configuration=en --configuration=production
时,出现错误Configuration 'en,production' could not be found
.据了解,您一次只能指定一种配置.
But when I'm doing ng build --configuration=en --configuration=production
I'm getting an error Configuration 'en,production' could not be found
. I understand it means you can specify only 1 configuration at a time.
这意味着我需要创建单独的en
,pl
,productionEn
,productionPl
配置.虽然不是最干净的模式,但我可以接受.
This means I need to create separate en
, pl
, productionEn
, productionPl
configurations. Though not the cleanest pattern, I can live with that.
"build": {
...
"configurations": {
"production": {
"fileReplacements": [
{
"replace": "src/environments/environment.ts",
"with": "src/environments/environment.prod.ts"
}
],
"optimization": true,
"outputHashing": "all",
"sourceMap": false,
"extractCss": true,
"namedChunks": false,
"aot": true,
"extractLicenses": true,
"vendorChunk": false,
"buildOptimizer": true
},
"pl": {
"fileReplacements": [
{
"replace": "src/assets/i18n/translations.json",
"with": "src/assets/i18n/pl.json"
}
]
},
"en": {
"fileReplacements": [
{
"replace": "src/assets/i18n/translations.json",
"with": "src/assets/i18n/en.json"
}
]
},
"productionPl": {
"fileReplacements": [
{
"replace": "src/environments/environment.ts",
"with": "src/environments/environment.prod.ts"
},
{
"replace": "src/assets/i18n/translations.json",
"with": "src/assets/i18n/pl.json"
}
],
"optimization": true,
"outputHashing": "all",
"sourceMap": false,
"extractCss": true,
"namedChunks": false,
"aot": true,
"extractLicenses": true,
"vendorChunk": false,
"buildOptimizer": true
},
"productionEn": {
"fileReplacements": [
{
"replace": "src/environments/environment.ts",
"with": "src/environments/environment.prod.ts"
},
{
"replace": "src/assets/i18n/translations.json",
"with": "src/assets/i18n/en.json"
}
],
"optimization": true,
"outputHashing": "all",
"sourceMap": false,
"extractCss": true,
"namedChunks": false,
"aot": true,
"extractLicenses": true,
"vendorChunk": false,
"buildOptimizer": true
}
}
}
但是我不能忍受的是将整个production
配置内容复制并粘贴到productionEn
和productionPl
中.如果我添加更多的语言环境,或在构建过程中要指定的第三个单独方面,则此模式将成为维护工作的噩梦.不幸的是,这似乎是Angular团队在其文档中推荐的模式.
But what I can't live with is copying and pasting the whole production
configuration contents into productionEn
and productionPl
. If I add even more locales, or some third separate aspect that I'd like to specify during build, this pattern would become a total nightmare to maintain. Unfortunately it seem it's the pattern that Angular team recommends in their documentation.
是否有一种方法可以告诉Angular CLI productionEn
扩展了production
,因此不会多次重复相同的配置代码?类似于以下代码:
Is there a way to tell Angular CLI that productionEn
extends production
, so to not duplicate the same configuration code multiple times? Something like the code below:
"build": {
...
"configurations": {
"production": {
(...)
},
"pl": {
"extends": "production",
(...)
},
"en": {
"extends": "production",
(...)
}
}
}
推荐答案
终于有了一种方法,可以在命令行中指定多个配置:
There finally is a way to do it, specifying multiple configurations in the command line:
ng build --configuration=en,production
这篇关于有没有办法扩展angular.json中的配置?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!