Step by step creating angular application with each labs
Angular is a declarative JavaScript framework to simply JavaScript code
In our applicatin, we generated with Angular CLI version 8.2.1
AngularJS was originally developed in 2009 by Miško Hevery and Adam Abrons. Abrons left the project, but Hevery, who works at Google, continues to develop and maintain the library with fellow Google employees Igor Minár and Vojta Jína.
- Sending Feedback
- Folder Structure
- Sample application with each labs
- Lab 1 - Angular overview
- Lab 2 - npm example
- Lab 3 - Setting up and running first angular application
- Lab 4 - Installing bootstrap for Angular
- Lab 5 - Angular Routing - Creating Master page and Navigators
- Lab 6 - Creating simple UI page
- Lab 7 - Implementing lazy loading and increase the performance of the application
- Lab 8 - Implementing validation
- Lab 9 - Dependency Injection
- Lab 10 - Making http calls
- Lab 11 - Services
- Lab 12 - Implementing pipes
For feedback can drop mail to my email address amit.naik8103@gmail.com or you can create issue
What and why we have to use Angular You can find answer here
Install Node and npm latest version
Install Angular CLI 8 or later
Install Visual Studio Code
$ npm init
$ npm install jquery --save
$ npm install angular --save
What is Major version, minor version and revision version
What is difference between ^, ~ and *
What is difference between dependency and devDependency
// Installing Angular CLI
$ npm install -g @angular/cli
$ npm -v
$ node -v
// Below are some Angular CLI
// To check angular CLI versions
$ ng --versions
$ ng v
// Another way to verify angular CLI in global level
$ npm list -g @angular/cli
// To upgrade angular CLI to latest version
$ npm uninstall -g @angular/cli
$ npm cache clean
$ npm install -g @angular/cli
// Getting help in Angular CLI
$ ng help
// Creating angular application without node_module folder
$ ng new project-name --skip-install
// Creating angular application
$ ng new project-name
Angular CLI is command line interface which helps to get basic setup of angular project
For eg: If we run, npm install --save angular
we will able to get angular 1.7.8 as updated in package-lock.json file, so angular-cli helps to get latest version of angular (currently 8) with basic setup of angular project
AngularJS means 1.X version Angular means 2.x or higher
// For dry run
$ ng new angular-application -d
// To create angular application
$ ng new angular-application
// to redirect to path
$ cd angular-application
// to run application in development mode
$ ng serve --open
$ ng s -o
// Open http://localhost:4200 to view it in the browser.
// to build application
$ ng build
// create dist folder which will go for production
angular.json -> Angular
package.json -> Node
tsconfig.json -> TypeScript
tslint.json -> Linting
runtime.js -> This is for webpack runtime
polyfill.js -> Helps to run new ES version javascript in old browser which does not support them
vendor.js -> Actual project code (component, modules, model)
main.js -> Points first module
style.js -> all css code
In this lab we will see how to integrate old javascript frameworks like bootstrap and jQuery with Angular
install bootstrap, jquery and @types/jquery to your package.json file
$ npm install bootstrap@3 --save
$ npm install @types/jquery --save
$ npm install jquery --save
// or you can all these command in one go
$ npm install bootstrap@3 @types/jquery jquery --save
Add below jquery to angular.json
"styles": [
"node_modules/bootstrap/dist/css/bootstrap.min.css"
],
"scripts": [
"node_modules/jquery/dist/jquery.min.js",
"node_modules/bootstrap/dist/js/bootstrap.min.js"
]
Check by adding button with css in app.component.html file
Welcome to {{ title }}! <br/>
<input type="button" value="Test" class="btn btn-primary">
Create Customer, Supplier and Home page using below command
$ ng g c Home/Home --skipTests --flat=true -is
$ ng g c Customer/Customer --skipTests --flat=true -is
$ ng g c Supplier/Supplier --skipTests --flat=true -is
--skipTests
is to skipt spec files
--flat
is to not create folder
-is
is to skip css files
Add below code snippet in app-routing.module
const routes: Routes = [
{ path: 'Home', component: HomeComponent },
{ path: 'Customer', component: CustomerComponent },
{ path: 'Supplier', component: SupplierComponent },
{ path: '', component: HomeComponent }
];
Add below code snippet in app.component.html
<div class="container">
<nav class="navbar navbar-default">
<ul class="nav navbar-nav">
+ <li routerLinkActive="active"><a routerLink="Home" >Home</a></li>
+ <li routerLinkActive="active"><a routerLink="Customer" >Customer</a></li>
+ <li routerLinkActive="active"><a routerLink="Supplier" >Supplier</a></li>
</ul>
</nav>
+ <router-outlet></router-outlet>
</div>
with moon-wrap html
div.container>nav.navbar.navbar-default>ul.nav.navbar-nav>li>a
(click on tab)
Create Customer Model class in customer folder using below command
$ ng g class Customer/customer-model --skipTests
Add below code snippet in customer-model.ts
export class CustomerModel {
CustomerCode: string;
CustomerName: string;
CustomerAmount: number;
}
Create simple UI page in customer.component.html
<div>
Customer code : <input type="text" [(ngModel)]="customerModel.CustomerCode" name="cCode" id="cCode"> <br>
Customer name : <input type="text" [(ngModel)]="customerModel.CustomerName" name="cName" id="cName"> <br>
Customer amount : <input type="text" [(ngModel)]="customerModel.CustomerAmount" name="cAmount" id="cAmount"> <br>
<input type="button" value="Add" (click)="Add()" >
<br>
{{customerModel.CustomerCode}} <br>
{{customerModel.CustomerName}} <br>
{{customerModel.CustomerAmount}} <br>
</div>
create customer object in customer.component.ts
import { CustomerModel } from './customer-model';
.
export class CustomerComponent implements OnInit {
.
.
customerModel: CustomerModel = new CustomerModel();
}
import FormsModule to app.module.ts file
import { FormsModule } from "@angular/forms";
.
.
@NgModule({
.
.
imports: [
BrowserModule,
AppRoutingModule, FormsModule
],
.
.
})
export class AppModule { }
Build and run application
create customers object in customer.component.ts
import { CustomerModel } from './customer-model';
.
export class CustomerComponent implements OnInit {
.
.
customerModel: CustomerModel = new CustomerModel();
customerModels: Array<CustomerModel> = new Array<CustomerModel>();
Add() {
this.customerModels.push(this.customerModel);
this.customerModel = new CustomerModel();
}
}
and bind to customer.component.html file
<table>
<tr>
<td>Customer code</td>
<td>Customer name</td>
<td>Customer amount</td>
</tr>
<tr *ngFor ="let cust of customerModels" >
<td>{{cust.CustomerCode}}</td>
<td>{{cust.CustomerName}}</td>
<td>{{cust.CustomerAmount}}</td>
</tr>
</table>
Build and run application
Property binding (UI to component) - []
Event binding (component to UI) - ()
Interpolation (Expression) - {{}}
Create Customer and Supplier module w.r.t component
$ ng g module Customer/Customer --flat=true --routing=true
$ ng g module Supplier/Supplier --flat=true --routing=true
Modify routes in app-routing.module.ts file
const routes: Routes = [
{ path: 'Home', component: HomeComponent },
{ path: 'Customer', loadChildren: './Customer/customer.module#CustomerModule' },
{ path: 'Supplier', loadChildren: './Supplier/supplier.module#SupplierModule' },
{ path: '', component: HomeComponent }
];
Modify routes in child file customer-routing.module.ts
const routes: Routes = [
{ path: 'Add', component: CustomerComponent }
];
Modify routes in child file supplier-routing.module.ts
const routes: Routes = [
{ path: '', component: SupplierComponent }
];
Remove CustomerComponent and SupplierComponent in app.module.ts file
Delcare CustomerComponent and SupplierComponent w.r.t its Module file
Add below code snippet in customer-model.ts
import { FormGroup, FormBuilder, FormControl, Validators } from '@angular/forms';
export class CustomerModel {
CustomerCode: string;
CustomerName: string;
CustomerAmount: number;
formCustomerGroup : FormGroup;
constructor(){
let builder = new FormBuilder();
this.formCustomerGroup = builder.group({});
this.formCustomerGroup.addControl("CustomerNameControl", new FormControl('', Validators.required));
let validationCollection =[];
validationCollection.push(Validators.required);
validationCollection.push(Validators.pattern("^[0-9]{4,4}$"));
this.formCustomerGroup.addControl("CustomerCodeControl", new FormControl('',Validators.compose(validationCollection)));
}
}
Add below code snippet in customer.component.html
<form [formGroup]="customerModel.formCustomerGroup">
Customer code : <input type="text" formControlName="CustomerCodeControl" [(ngModel)]="customerModel.CustomerCode"
name="cCode" id="cCode"> <br>
Customer name : <input type="text" formControlName="CustomerNameControl" [(ngModel)]="customerModel.CustomerName"
name="cName" id="cName"> <br>
Customer amount : <input type="text" [(ngModel)]="customerModel.CustomerAmount" name="cAmount" id="cAmount"
[ngModelOptions]="{standalone: true}"> <br>
<input type="button" value="Add" (click)="Add()" [disabled]="!(customerModel.formCustomerGroup.valid)">
<br>
{{customerModel.CustomerCode}} <br>
{{customerModel.CustomerName}} <br>
{{customerModel.CustomerAmount}} <br>
<div *ngIf="customerModel.formCustomerGroup.dirty" [hidden]="!(hasError('pattern', 'CustomerCodeControl'))">Customer
code
format is not proper</div>
<div *ngIf="customerModel.formCustomerGroup.dirty" [hidden]="!(hasError('required', 'CustomerNameControl'))">
Customer
code is required</div>
<div *ngIf="customerModel.formCustomerGroup.dirty" [hidden]="!(hasError('required', 'CustomerNameControl'))">
Customer name is required</div>
// ...
</form>
Add below code snippet in customer.component.ts
hasError(typeofValidator: string, controlName: string): boolean { return this.customerModel.formCustomerGroup.controls[controlName].hasError(typeofValidator);
}
There is two types of DI
- Centrailised DI
- Conditional DI
Create interface with inheritance logger file (eg. ILogger.ts) in Utility folder
export interface ILogger {
Log();
}
export class BaseLogger implements ILogger {
Log() {
}
}
export class ConsoleLogger extends BaseLogger {
Log() {
console.log("consoler logger");
}
}
export class DbLogger extends BaseLogger {
Log() {
console.log("DB logger");
}
}
Adding BaseLogger to app.module.ts
providers: [
// centralised DI
{ provide: BaseLogger, useClass: DbLogger },
]
Add below line in the component file
export class CustomerComponent implements OnInit {
logObj: BaseLogger;
constructor(log: BaseLogger) {
this.logObj = log;
this.logObj.Log();
}
For conditional based DI
providers: [
// centralised DI
{ provide: BaseLogger, useClass: ConsoleLogger },
// Conditional DI
{ provide: '1', useClass: ConsoleLogger },
{ provide: '2', useClass: DbLogger },
],
In Customer component
logObj: BaseLogger;
constructor(log: Injector) {
this.logObj = log.get('1');
this.logObj.Log();
}
To create fake API, run below command
npm install -g json-server
To run fake API, create new terminal and run below command
json-server --watch db.json
Replace below code snippet to db.json
{
"Customers": [
{
"id": 1,
"CustomerCode": "1001",
"CustomerName": "Amit",
"CustomerAmount": "50000"
}
]
}
Add button in customer.component.html file
<input type="button" value="Post to server" (click)="PostToServer()">
Add below code snippet in customer.component.ts
constructor(log: Injector, public http: HttpClient) {
//--
}
PostToServer() {
let custDTO: any = {};
custDTO.CustomerCode = this.customerModel.CustomerCode;
custDTO.CustomerName = this.customerModel.CustomerName;
custDTO.CustomerAmount = this.customerModel.CustomerAmount;
this.http.post('http://localhost:3000/Customers', custDTO)
.subscribe(res => this.Success(res), res => this.Error(res))
}
GetFromServer() {
this.http.get('http://localhost:3000/Customers')
.subscribe(res => this.SuccessGet(res), res => this.Error(res))
}
Success(res) {
this.GetFromServer();
}
Error(res) {
console.log(res);
}
SuccessGet(res) {
this.customerModels = res;
this.customerModel = new CustomerModel();
}
Create Service.ts file
import { HttpInterceptor, HttpRequest, HttpHandler, HttpEvent } from "@angular/common/http";
import { Observable } from 'rxjs';
export class MyInterceptor implements HttpInterceptor {
intercept(req: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {
req = req.clone({
setHeaders: {
"security-key": "key123"
}
});
return next.handle(req);
}
}
In app.module.ts
providers:[
// For service
{ provide: HTTP_INTERCEPTORS, useClass: MyInterceptor, multi: true }
]
import { Pipe, PipeTransform } from '@angular/core';
// tslint:disable-next-line: use-pipe-transform-interface
@Pipe({ name: 'reverseit' })
export class ReverseString {
transform(value: string): string {
return value.split('').reverse().join('');
}
}
In app.module.ts
declarations: [......,
ReverseString],