ALL >> Technology,-Gadget-and-Science >> View Article
How To Have Various Environments With Angular Cli Future (angular 7)

As a result of this, we would need builds of different configurations: Different server URLs, different constants, different logging options, etc.
Angular CLI offers an environment feature that allows running builds targeted at specific environments for specific requirements. For instance, here is how you would run a build for production:
ng build — env=prod // up to Angular 5
Update: With Angular 6 and Above, the command is now:
ng build — configuration=production // new versions
The prod flag in the above code refers to the prod (production in v6 and above) property of the environments section of .angular-cli.json before v6:(now angular.json in v6 and above), which has two options by default: dev and prod
“environments”: {
“dev”: “environments/environment.ts”,
“prod”: “environments/environment.prod.ts”
}
You can add as many environments as you need here and name them accordingly. For instance, if you need a assesment build option, just add the following entry in .angular-cli.json:
“environments”: {
“dev”: “environments/environment.ts”,
...
... “prod”: “environments/environment.prod.ts”,
“qa”: “environments/environment.qa.ts”
}
For v6 and above, angular.json environments are now called configurations. Here is how to add a new qa environment after v6:
“configurations”: {
“production”: { … },
“qa”: {
“file replacements”: [
{
“replace”: “src/environments/environment.ts”,
“with”: “src/environments/environment.qa.ts”
}
]
}
}
Then you have to create the actual file environment.qa.ts in the environments directory.
Here is what the default environment.ts file for dev looks like:
// The file contents for the current environment will overwrite these during build.
// The build system defaults to the dev environment which uses `environment.ts`, but if you do
// `ng build — env=prod` then `environment.prod.ts` will be used instead.
// The list of which env maps to which file can be found in `.angular-cli.json`.
export const environment = {
production: false
};
The above environment object is where you would add any environment specific property. For instance, let’s add a server URL:
export const environment = {
production: false,
serverUrl: “http://dev.server.companyName.com"
};
Then all you have to do to provide a different URL for QA is to define that same property with the right value in environment.qa.ts:
export const environment = {
production: false,
serverUrl: “http://qa.server.companyName.com"
};
Now that your environments are defined, how do you use those properties in your code? Easy enough, all you have to do is import the environment objects as follows:
import {environment} from ‘../../environments/environment’;
@Injectable()
export class AuthService { API_URL: string = environment.server Url + ‘/theUrlForAPI’ ;
Then when you run a build for QA, Angular CLI is going to use environment.qa.ts to read the environment.server Url property value and you’re all set to deploy that build to the QA environment.
My Name is Prateek Pandey. I am a Developer, as well as consultant, and trainer for Angular where I help web developers learn and ease the stuff.
For more information click here -: https://letsmobility.com/
Add Comment
Technology, Gadget and Science Articles
1. Top 5 Mistakes To Avoid With Apostilled Translations In GlasgowAuthor: glasgowtranslationservices
2. Comparing In-house Vs. Freelance Academic Translation In London: Which Is Better?
Author: londontranslationservice
3. Collaboration Features In Video Platforms
Author: Zyan
4. The Role Of Translation Services In The Entertainment Industry
Author: premiumlinguisticservices
5. Kentico To Umbraco Migration: A Complete Guide For Seamless Transition
Author: Addxp Technologies
6. How To Use Data Analytics To Improve Your Marketing Campaigns: Social Media & Emerging Tech
Author: jatin
7. Busch Group Presents Innovative Vacuum Solutions At Battery Show Europe 2025 In Stuttgart
Author: Busch Vacuum Solutions
8. Myteam11 Data Scraping Helps Decode Player Trends For Winning Predictions
Author: Retail Scrape
9. Banners For Trade Shows: Standing Out In A Crowded Marketplace
Author: printitusa
10. Get Complete Solutions When You Get Your Business Tied To A Virtual Receptionist
Author: Eliza Garran
11. The Fundamentals Of A Successful Website That Gives A Winning Edge To Entrepreneurs
Author: Liam Mackie
12. How Seo Can Make Your Website Friendly For Google Page Ranking?
Author: Liam Mackie
13. The Call Answering Service Is A Must For Every Business Type!
Author: Eliza Garran
14. Choosing The Best Compliance Management Software: A Modern Business Imperative
Author: vishva
15. Web Scraping Food Delivery Platforms For Competitive Intelligence
Author: Food Data Scrape