Angular: Is a JS framework which helps us to build web pages effectively. SPA(Single Page Applications) can be implemented using Angular.
SPA > Only one HTML page is served from the server along with a bundle of JS, the JS bundle controls and renders the DOM elements on the page based on the user routes.This helps to avoid server calls for each page and increases the performance of the Application and re-activeness of the Web page.
Angular CLI(Command Line Instruction) > Is a set of tools that can be used to create, manage and build angular applications.
Core Parts of an Angular app:
- Main.ts=> Part where the execution of our application starts, it specifies the bootstrap module and other configs
- Module=> Modules are the place where we declare the various objects(directives, services, other imported modules, bootstrap component etc.) we use in our application. Basically, modules declare and set up the environment in which our app runs. 
- Directives=> Directives are used to specify the special meaning to the DOM elements in our HTML file.
- Services=> Singleton services help us in organizing and sharing the code base across our app. Services are mainly used in organizing http calls and shared data across the app.
MODULESare identified by @ngModule Decorator and have sections like Declarations(to declare the directives, pipes etc), Providers(to declare the services both custom and built-in), Imports(to declare the built-in modules used and user-defined modules), Bootstrap(to declare the bootstrap component of the application)
DIRECTIVES are of 3 types:
- Structural directives(modify/inject the DOM elements structures based on the conditions).
- Attribute directives(alter the attribute/properties of the DOM element custom attribute directives can be created using @Directive decorator).
- Components(it is a special type of directive which has an HTML template associated with it. Components are the building blocks of our app. Components inject the associated HTML templates where ever the component selector is present. Components are identified by the @Component decorator).
PIPES help us in transforming the data to the appropriate form and displaying to the user. Custom pipes can be created using the @pipes directive. Some of the built-in pipes are date, lowercase, uppercase, currency etc.
Steps to set up an angular project:
- Install Node JS from https://nodejs.org/en/. (though we are not going to code in node, it is a requirement for the CLI),
- Install angular CLI by running the command : npm install -g @angular/cli
- Create a new angular project by using command : ng new project-name (eg: C:\Project> ng new SampleProject)
- To run the application navigate into the new project and use the command ng serve (eg: C:\Project\SampleProject> ng serve).This will run a local server which will host the application. You can view the output/application by using the localhost URL specified in the console.
Example:localhost:4200 
 
 
- The project can be opened using Sublime, VS code etc.
- The  project structure looks like the following:  
- The index.html file will be the only html file served by the server, and all other components will be bundled and sent to the browser.
- main.ts file is the first/start file to be executed in the application, which provides the information about bootstrap module and enable prod mode.
- By default AppModule is the bootstrap module. (Module is nothing but the container/package of components. It has 4 attributes, Declarations: List of Components the system must know and use. Imports: To declare the custom modules in the application, which in turn is a module by itself. Bootstrap: Which component must be know by the index,html on startup. Providers: To declare the services).                                          
- By default in app.module.ts, AppComponent is set as bootstrap component. Thus, AppComponent is the component to be known by index.html at first.
- The contents of index.html is:                           the custom tag "<app-root></app-root>", is nothing but the selector of a "bootstrap-component" which will be replaced by the template of the particular component. In this case, the custom tag "<app-root></app-root>", is nothing but the selector of a "bootstrap-component" which will be replaced by the template of the particular component. In this case,
 "<app-root></app-root>" is the selector of AppComponent, thus the tag
 "<app-root></app-root>" is replaced by the tempate specified in appcomponent. 
 Adding a new component and using it in app.component:
 
Adding a new component and using it in app.component: 
-  We can either add modules manually or create them using the following command ng g c component-name 
 (eg: C:\Project\SampleProject> ng g c newComponent)  
After a new component is created in order to use them, we must make the system to know there is a component which is done by adding a entry on the app.module.ts inside the declarations. Once this is done, we can use the selector of this new component in any others and its template will be rendered.
 
Output:
 
 
 
FORMS:
- TEMPLATE DRIVEN FORM
- REACTIVE FORM(MODEL DRIVEN FORM)
TEMPLATE DRIVEN FORMS the form-controls are not generated from the code side rather (hardcoded on the template file) generated and managed by the directives. They are asynchronous in nature as the work of rendering is deligated and managed by parent and child directives. This leads to a special type of error "Changed after checked" when the form is very much reactive in nature.
REACTIVE FORM, on the other hand, all the controls are generated and managed form the ts files and they are synchronous in nature. The 3 basic components in a Reactive form are FormControl, FormGroup, FormArray.
 
eg.
ts:
import { Component, OnInit } from '@angular/core';
import { FormGroup, FormControl, FormBuilder, Validators } from '@angular/forms';
import { User } from './user.interface';
@Component({
  moduleId: module.id,
  selector: 'my-app',
  templateUrl: 'app.component.html',
})
export class AppComponent implements OnInit {
    heroForm:FormGroup;
   name=new FormControl("initialvalue",Validators.required);
    sampleFormGrp=new FormGroup({
        controlInsideForm:new FormControl("Control inside form",Validators.required)
    });   
       
    constructor(private _fb: FormBuilder) {
      
    }
    ngOnInit() {
         this.heroForm = this._fb.group({
        name: ['using formbuilder it is easy to manage and maintain the formgrps', Validators.required ],
        });
    }
    }
html:
<form>
    <input type="text" [formControl]="name" />
    {{name.status}}
    </form> 
   
    <form [formGroup]="sampleFormGrp">
      <input type="text" formControlName="controlInsideForm" />
      </form>
sampleFormGrp values: {{sampleFormGrp.value| json}}
controlInsideForm value: {{sampleFormGrp.get("controlInsideForm").value}}
controlInsideForm status: {{sampleFormGrp.get("controlInsideForm").status}}
sampleFormGrp status: {{sampleFormGrp.status}}
<form [formGroup]="heroForm">
      <input type="text" formControlName="name" />
      </form>