詳解如何在Angular中使用環(huán)境變量
簡介
如果你正在構建一個使用 API 的應用程序,你會想在開發(fā)過程中使用測試環(huán)境的 API 密鑰,而在生產環(huán)境中使用生產環(huán)境的 API 密鑰。在 Angular 中,你可以通過 environment.ts 文件創(chuàng)建環(huán)境變量。
在本教程中,你將學習如何在 Angular 中使用環(huán)境變量。
先決條件
如果你想跟著本文操作,你需要:
- 一個用于 Node.js 的本地開發(fā)環(huán)境。請參考《如何安裝 Node.js 并創(chuàng)建本地開發(fā)環(huán)境》。
本教程已經驗證過可以在 Node v16.2.0、npm v7.15.1 和 @angular/core v12.0.3 下運行。
檢測環(huán)境
Angular CLI 項目已經使用了一個 production 環(huán)境變量,在生產環(huán)境下啟用生產模式:
// ...
if (environment.production) {
enableProdMode();
}
Angular 還為我們提供了一個名為 isDevMode 的實用函數,可以用來檢查應用程序是否在開發(fā)模式下運行:
import { Component, OnInit, isDevMode } from '@angular/core';
@Component({ ... })
export class AppComponent implements OnInit {
ngOnInit() {
if (isDevMode()) {
console.log('Development!');
} else {
console.log('Production!');
}
}
}
這個示例代碼將在開發(fā)模式下記錄消息 'Development!',在生產模式下記錄消息 'Production!'。
添加開發(fā)和生產變量
你還會注意到,默認情況下,在 /src/environment 文件夾中有一個用于開發(fā)環(huán)境和一個用于生產環(huán)境的環(huán)境文件。
假設我們想要根據是否處于開發(fā)或生產模式來使用不同的密鑰:
對于 environment.ts 中的開發(fā)設置:
export const environment = {
production: false,
apiKey: 'devKey'
};
對于 environment.prod.ts 中的生產設置:
export const environment = {
production: true,
apiKey: 'prodKey'
};
在我們的組件中,我們只需要這樣做就可以訪問變量:
import { Component } from '@angular/core';
import { environment } from '../environments/environment';
Angular 會負責切換正確的環(huán)境文件。
使用以下命令運行開發(fā)模式:
ng serve
apiKey 變量將解析為 devKey。
使用以下命令運行生產模式:
ng serve --configuration=production
apiKey 變量將解析為 prodKey。
添加暫存變量
通過在 angular.json 文件的 configurations 字段中添加新條目,可以在 Angular CLI 項目中添加新的環(huán)境。
讓我們基于生產使用的配置添加一個暫存環(huán)境:
{
// ...
"projects": {
"angular-environment-example": {
// ...
"prefix": "app",
"build": {
// ...
"configurations": {
"staging": {
// ...
"fileReplacements": [
{
"replace": "src/environments/environment.ts",
"with": "src/environments/environment.stage.ts"
}
],
// ...
},
// ...
},
},
"serve": {
"builder": "@angular-devkit/build-angular:dev-server",
"configurations": {
"staging": {
"browserTarget": "angular-environment-example:build:staging"
},
}
},
}
}
}
}
現在我們可以添加一個暫存環(huán)境文件:
export const environment = {
production: true,
apiKey: 'stagingKey'
};
使用以下命令運行開發(fā)模式:
ng serve --configuration=staging
apiKey 變量將解析為 stagingKey。
結論
在本教程中,你學習了如何在 Angular 中使用環(huán)境變量。
如果你想了解更多關于 Angular 的知識,請查看我們的 Angular 主題頁面,了解練習和編程項目。
以上就是詳解如何在Angular中使用環(huán)境變量的詳細內容,更多關于Angular環(huán)境變量的資料請關注腳本之家其它相關文章!
相關文章
AngularJS實現的獲取焦點及失去焦點時的表單驗證功能示例
這篇文章主要介紹了AngularJS實現的獲取焦點及失去焦點時的表單驗證功能,涉及AngularJS使用ng-blur、ng-focus針對表單事件監(jiān)聽相關操作技巧,需要的朋友可以參考下2017-10-10
Angularjs中ng-repeat-start與ng-repeat-end的用法實例介紹
這篇文章主要給大家介紹了Angularjs中ng-repeat-start與ng-repeat-end的用法,文章開始先進行了簡單的介紹,而后通過完整的實例代碼詳細給大家介紹這兩者的用法,有需要的朋友們可以參考借鑒,下面來一起看看吧。2016-12-12

