Angular在多環(huán)境配置配置enviroments

1.如果是生產(chǎn)模式辣卒,關(guān)閉angular的所有l(wèi)og。
在main.ts的入口文件中扼菠,

main.ts
import { enableProdMode } from '@angular/core';
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';

import { AppModule } from './app/app.module';
import { environment } from './environments/environment';
if(enviroment.production){
enableProdMode();
window.console.log=function(){};
window.console.info=function(){};
window.console.warn=function(){};
window.console.error=function(){};
window.console.debug=function(){};

platformBrowserDynamic().bootstrapModule(AppModule)
  .catch(err => console.error(err));
}

在環(huán)境中配置不同的enviroments

environment.prod.ts
export const environment = {
  production: true
...一些其他的不同環(huán)境的配置
一些url的配置
};


默認配置


environment.ts

// This file can be replaced during build by using the `fileReplacements` array.
// `ng build --prod` replaces `environment.ts` with `environment.prod.ts`.
// The list of file replacements can be found in `angular.json`.

export const environment = {
  production: false
};

/*
 * For easier debugging in development mode, you can import the following file
 * to ignore zone related error stack frames such as `zone.run`, `zoneDelegate.invokeTask`.
 *
 * This import should be commented out in production mode because it will have a negative impact
 * on performance if an error is thrown.
 */
// import 'zone.js/dist/zone-error';  // Included with Angular CLI.

增加配置

environment.prod..dit.ts
export const environment = {
  production: true
...一些其他的不同環(huán)境的配置
一些url的配置
};

4配置多環(huán)境在angular.json中配置

{
    "$schema": "./node_modules/@angular/cli/lib/config/schema.json",
    "version": 1,
    "newProjectRoot": "projects",
    "projects": {
        "my-app": {
            "root": "",
            "sourceRoot": "src",
            "projectType": "application",
            "prefix": "app",
            "schematics": {},
            "architect": {
                "build": {
                    "builder": "@angular-devkit/build-angular:browser",
                    "options": {
                        "outputPath": "dist/my-app",
                        "index": "src/index.html",
                        "main": "src/main.ts",
                        "polyfills": "src/polyfills.ts",
                        "tsConfig": "src/tsconfig.app.json",
                        "assets": [
                            "src/favicon.ico",
                            "src/assets"
                        ],
                        "styles": [
                            "src/styles.css",
                            "./node_modules/bootstrap/dist/css/bootstrap.css"
                        ],
                        "scripts": [
                            "./node_modules/jquery/dist/jquery.js",
                            "./node_modules/bootstrap/dist/js/bootstrap.js"
                        ]
                    },
                    "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,
                            "budgets": [{
                                "type": "initial",
                                "maximumWarning": "2mb",
                                "maximumError": "5mb"
                            }]
                        }
                            //增加的dit配置
                      "dit": {
                            "fileReplacements": [{
                                "replace": "src/environments/environment.ts",
                                "with": "src/environments/environment.dit.ts"
                            }],
                            "optimization": true,
                            "outputHashing": "all",
                            "sourceMap": false,
                            "extractCss": true,
                            "namedChunks": false,
                            "aot": true,
                            "extractLicenses": true,
                            "vendorChunk": false,
                            "buildOptimizer": true,
                            "budgets": [{
                                "type": "initial",
                                "maximumWarning": "2mb",
                                "maximumError": "5mb"
                            }]
                        }
                    }
                },
                "serve": {
                    "builder": "@angular-devkit/build-angular:dev-server",
                    "options": {
                        "browserTarget": "my-app:build"
                    },
                    "configurations": {
                        "production": {
                            "browserTarget": "my-app:build:production"
                        } ,
                    //這里是增加的dit環(huán)境
                        "dit": {
                             "browserTarget": "my-app:build:dit"
                        }
                    }
                },
                "extract-i18n": {
                    "builder": "@angular-devkit/build-angular:extract-i18n",
                    "options": {
                        "browserTarget": "my-app:build"
                    }
                },
                "test": {
                    "builder": "@angular-devkit/build-angular:karma",
                    "options": {
                        "main": "src/test.ts",
                        "polyfills": "src/polyfills.ts",
                        "tsConfig": "src/tsconfig.spec.json",
                        "karmaConfig": "src/karma.conf.js",
                        "styles": [
                            "src/styles.css"
                        ],
                        "scripts": [],
                        "assets": [
                            "src/favicon.ico",
                            "src/assets"
                        ]
                    }
                },
                "lint": {
                    "builder": "@angular-devkit/build-angular:tslint",
                    "options": {
                        "tsConfig": [
                            "src/tsconfig.app.json",
                            "src/tsconfig.spec.json"
                        ],
                        "exclude": [
                            "**/node_modules/**"
                        ]
                    }
                }
            }
        },
        "my-app-e2e": {
            "root": "e2e/",
            "projectType": "application",
            "prefix": "",
            "architect": {
                "e2e": {
                    "builder": "@angular-devkit/build-angular:protractor",
                    "options": {
                        "protractorConfig": "e2e/protractor.conf.js",
                        "devServerTarget": "my-app:serve"
                    },
                    "configurations": {
                        "production": {
                            "devServerTarget": "my-app:serve:production"
                        }
                    }
                },
                "lint": {
                    "builder": "@angular-devkit/build-angular:tslint",
                    "options": {
                        "tsConfig": "e2e/tsconfig.e2e.json",
                        "exclude": [
                            "**/node_modules/**"
                        ]
                    }
                }
            }
        }
    },
    "defaultProject": "my-app"
}

5文件打包
下面的是兩種打包命令 npm run build
npm run builddit 尼荆,這個命令執(zhí)行的是上面增加的dit配置文件
test也是經(jīng)過 配置 --code-coverage

...
  "scripts": {
    "ng": "ng",
    "start": "ng serve",
    "build": "ng build --base-href  ./ ",
    "builddit": "ng build --prod --base-href  ./   --configuration=dit",
    "test": "ng test  --watch=false  --code-coverage",
    "lint": "ng lint",
    "e2e": "ng e2e"
  },
...
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市诈泼,隨后出現(xiàn)的幾起案子懂拾,更是在濱河造成了極大的恐慌,老刑警劉巖厂汗,帶你破解...
    沈念sama閱讀 216,651評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件委粉,死亡現(xiàn)場離奇詭異,居然都是意外死亡娶桦,警方通過查閱死者的電腦和手機贾节,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,468評論 3 392
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來衷畦,“玉大人栗涂,你說我怎么就攤上這事∑碚” “怎么了斤程?”我有些...
    開封第一講書人閱讀 162,931評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我忿墅,道長扁藕,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,218評論 1 292
  • 正文 為了忘掉前任疚脐,我火速辦了婚禮亿柑,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘棍弄。我一直安慰自己望薄,他們只是感情好,可當我...
    茶點故事閱讀 67,234評論 6 388
  • 文/花漫 我一把揭開白布呼畸。 她就那樣靜靜地躺著痕支,像睡著了一般。 火紅的嫁衣襯著肌膚如雪蛮原。 梳的紋絲不亂的頭發(fā)上卧须,一...
    開封第一講書人閱讀 51,198評論 1 299
  • 那天,我揣著相機與錄音瞬痘,去河邊找鬼故慈。 笑死,一個胖子當著我的面吹牛框全,可吹牛的內(nèi)容都是我干的察绷。 我是一名探鬼主播,決...
    沈念sama閱讀 40,084評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼津辩,長吁一口氣:“原來是場噩夢啊……” “哼拆撼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起喘沿,我...
    開封第一講書人閱讀 38,926評論 0 274
  • 序言:老撾萬榮一對情侶失蹤闸度,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后蚜印,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體莺禁,經(jīng)...
    沈念sama閱讀 45,341評論 1 311
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,563評論 2 333
  • 正文 我和宋清朗相戀三年窄赋,在試婚紗的時候發(fā)現(xiàn)自己被綠了哟冬。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,731評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡忆绰,死狀恐怖浩峡,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情错敢,我是刑警寧澤翰灾,帶...
    沈念sama閱讀 35,430評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響纸淮,放射性物質(zhì)發(fā)生泄漏平斩。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,036評論 3 326
  • 文/蒙蒙 一萎馅、第九天 我趴在偏房一處隱蔽的房頂上張望双戳。 院中可真熱鬧,春花似錦糜芳、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,676評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至晃虫,卻和暖如春皆撩,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背哲银。 一陣腳步聲響...
    開封第一講書人閱讀 32,829評論 1 269
  • 我被黑心中介騙來泰國打工扛吞, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人荆责。 一個月前我還...
    沈念sama閱讀 47,743評論 2 368
  • 正文 我出身青樓滥比,卻偏偏與公主長得像,于是被迫代替她去往敵國和親做院。 傳聞我的和親對象是個殘疾皇子盲泛,可洞房花燭夜當晚...
    茶點故事閱讀 44,629評論 2 354

推薦閱讀更多精彩內(nèi)容