SlideShare a Scribd company logo
ANGULAR
FROM ZERO TO MASTERY
Algiers 22/11/2020 Presented By Smail LOUNES
linkedin.com/in/smail-lounes/
twitter.com/smaillns
es_lounes@esi.dz
Formation Outline
By the end ..
Cover most Angular notions
Be able to build a complete web app with Angular
Prerequisites
Introduction
3-Tier Architecture
Presentation Layer Buisness Layer Data Layer
Frontend Backend
Frontend frameworks
OVERVIEW
What's Angular ?
Angular is an application design framework and development
platform for creating efficient and sophisticated single-page apps.
angular.io
Why Angular ?
67,4 k
Made with
Angular
DEVELOP ACROSS ALL PLATFORMS
SPEED & PERFORMANCE
INCREDIBLE TOOLING, HIGH PRODUCTIVITY
LARGE COMMUNITY
Angular app architecture
Angular app architecture Module
Component
Child-
Component
Child-
Component
Service
Component
Service1
Service2
ECOSYSTEM
Setting Up The Dev Environnement
Settting Up Git
Download the git installer for your specific
computing platform
https://git-scm.com/downloads
Text Editor of your choice
https://code.visualstudio.com/
Web Browser
Node.JS & NPM
Angular requires NodeJS
http://nodejs.org/
Install Angular CLI
Command line interface for
Anngular
% npm install -g @angular/cli
First
Application
Generate the application
Open it with IDE
Configure Angular CLI
Configure & run the application
% ng new project-name
Angular from Zero to Mastery - Training (Intermediate)
MAIN CONCEPTS
Angular Main Building Blocks
Component, templates and views
View
Component life cycle hook
View Encapsulation
Create a new component
Component Interaction next
Data binding
- {} Interpolation
- [] Property Binding
- Event Binding
- two-way data binding
the four forms of data binding
markup
Listen to child event with
@Output binding
Inject Child component into
parent as a ViewChild
Pass data from parent to child with
@Input binding
Communication via a Service next
NgOnChanges()
Services
A Service is a class with @Injectable decorator encompassing any
value, function, or feature that an app needs.
A service has a well-defined purpose. It should do something
specific and do it well.
Angular distinguishes components from services to increase
modularity and reusability
A component can delegate certain tasks to services, such as
fetching data from the server, validating user input ...
Dependency Injection
Process of HeroService injection
tree-shaking
Generate a new service
Parent and children communicate
via a service
Provide a Service on a
specific module/component
Pipes
A class with the @Pipe decorator defines a function that transforms input
values to output values for display in a view
https://angular.io/api?type=pipe
Use some of Angular pipes (date,
currency, lowercase ...)
Define a new pipe
Directives
Angular templates are dynamic. When Angular renders them, it transforms
the DOM according to the instructions given by directives.
A directive is a class with a @Directive() decorator.
In addition to components, there are two other kinds of
directives: structural and attribute.
Structural Directive Attribute Directives
*ngIF ; *ngFor; *ngSwitch [(ngModel)]
ngStyle, ngClass
*ngIF; *ngFor; *ngStyle; *ngClass
Directives
Some
TypeScript tricks
ROUTING
&
NAVIGATION
Setting up wildcard routes
Displaying 404 Page
Define some routes
Redirects
routerLink
Router, AcitvatedRoute
LazyLoading
Router resolver
FROMS
Forms in Angular
Angular supports two (2) design approches for
interactive forms :
Template-driven forms
Reactive forms
Applications uses forms to enable users to log in, update profile, to
enter sensitive information and to perform many other data-entry tasks
Angular from Zero to Mastery - Training (Intermediate)
Building reactive form
HTTP Client
HttpClient service
@angular/co
mmon/http
Http requests
Use the Angular client HTTP API to access back-end services
Http Client use cases
Setting up a mock server
RxJS
Some RxJs operators
pipe
SwitchMap
MATERIAL
Modals and Pop-ups
Icons
Customizing theme
Add some Angular Material components
Buttons
Snackbar
Sidebar
FLEX LAYOUT
CSS Flexbox
Angular Flex-Layout
JWT
Authentication
- Application should know who the user is
Authorization
- Application should know what user can do
JWT – Json Web Token
JWT token contains information about a user
DON'T STORE PASSWORDS AS PLAIN TEXT ! Bearer eyJhbG
ciOiIUzI1NiIsInR
5cCI6IkpXVCJ9.
eyJzdWIiOiIxMj
Server
JWT interceptor
Add AuthGuard (managing route access)
Mock Authentication
PWA
SSR
Facilitate web crawlers through search engine optimization (SEO)
Improve performance on mobile and low-powered devices
Show the first page quickly with a first-contentful paint (FCP)
Why use server-side rendering?​
i18n
Internationalization (i18n)
Deploy
Application
Mini Project
FROM ZERO TO MASTERY
ANGULAR
Mini-Project
• SPÉFICATIONS
Bref Resumé
Spécifications fonctionnelles
Spécifications techniques
• ARCHITECTURE
• MAQUETTES DU PROJET
SOMMAIRE
Spéficiations
Fontionnelles
• L'application doit permettre de lister les lieux touristiques
d'Algérie
• Permet de les filtrer Par Wilaya/Catégorie
• L'application doit permettre d'afficher le détails d'un lieu
(Nom, Description, infos, Images, etc)
• Elle doit permettre à un utilisateur de créer un compte et
de s'authentifier
• L'application doit permettre à un utilsateur authentifié
d'ajouter un nouveau spot, modifier ces infos et le
supprimer
• L'application permet d'ajouter ou de
supprimer un spot aux/de favoris
• ...
Non-fontionnelles
• L'application web doit etre développé avec Angular
• L'interface de l'application doit etre résponsive et
ergonomique
• Elle doit adopter le Material Design
• Elle doit supporter le design RTL
La solution 'Dzair' consiste en une application web qui exhibe les différents monuments et lieux touristiques
( musées, plages, parcs, restaurants, etc) de l'Algérie
Architecture de l'application
Angular from Zero to Mastery - Training (Intermediate)
Angular from Zero to Mastery - Training (Intermediate)

More Related Content

PPTX
AngularJS 1.x - your first application (problems and solutions)
PPTX
Introduction to angular | Concepts and Environment setup
PPTX
Angular 18 course for begineers and experienced
PDF
Angular meetup 2 2019-08-29
PPTX
Angularjs basic part01
PPTX
Presentation on angular 5
PDF
AngularJS 101
PDF
Angular JS 2_0 BCS CTO_in_Res V3
AngularJS 1.x - your first application (problems and solutions)
Introduction to angular | Concepts and Environment setup
Angular 18 course for begineers and experienced
Angular meetup 2 2019-08-29
Angularjs basic part01
Presentation on angular 5
AngularJS 101
Angular JS 2_0 BCS CTO_in_Res V3

Similar to Angular from Zero to Mastery - Training (Intermediate) (20)

PPTX
PDF
Angular Meetup 1 - Angular Basics and Workshop
PDF
Download full ebook of Become a ninja with Angular Ninja Squad instant downlo...
PPTX
The future of web development write once, run everywhere with angular.js and ...
PDF
The future of web development write once, run everywhere with angular js an...
PPTX
Walk in the shoe of angular
PPTX
Foster - Getting started with Angular
PPTX
angular javascript interview questions with talent titan.pptx
PPTX
Angular Basics: A Beginner's Guide to Web Development
PPTX
AngularJS Introduction (Talk given on Aug 5 2013)
PDF
Myths of Angular 2: What Angular Really Is
PPTX
Angular js
PDF
Responsive web design with Angularjs
PDF
Ng-init
PDF
Ng-init
PDF
Angular Notes.pdf
PPTX
Intro to AngularJs
PPTX
Angular patterns
PDF
Angular js
PDF
Angular js
Angular Meetup 1 - Angular Basics and Workshop
Download full ebook of Become a ninja with Angular Ninja Squad instant downlo...
The future of web development write once, run everywhere with angular.js and ...
The future of web development write once, run everywhere with angular js an...
Walk in the shoe of angular
Foster - Getting started with Angular
angular javascript interview questions with talent titan.pptx
Angular Basics: A Beginner's Guide to Web Development
AngularJS Introduction (Talk given on Aug 5 2013)
Myths of Angular 2: What Angular Really Is
Angular js
Responsive web design with Angularjs
Ng-init
Ng-init
Angular Notes.pdf
Intro to AngularJs
Angular patterns
Angular js
Angular js
Ad

Recently uploaded (20)

PPTX
Agentic AI Use Case- Contract Lifecycle Management (CLM).pptx
PDF
Understanding Forklifts - TECH EHS Solution
PDF
PTS Company Brochure 2025 (1).pdf.......
PDF
medical staffing services at VALiNTRY
PPTX
ai tools demonstartion for schools and inter college
PDF
Which alternative to Crystal Reports is best for small or large businesses.pdf
PPTX
Embracing Complexity in Serverless! GOTO Serverless Bengaluru
PPTX
history of c programming in notes for students .pptx
PDF
Wondershare Filmora 15 Crack With Activation Key [2025
PDF
Digital Systems & Binary Numbers (comprehensive )
PPTX
L1 - Introduction to python Backend.pptx
PDF
top salesforce developer skills in 2025.pdf
PDF
Internet Downloader Manager (IDM) Crack 6.42 Build 41
PDF
Claude Code: Everyone is a 10x Developer - A Comprehensive AI-Powered CLI Tool
PPTX
Computer Software and OS of computer science of grade 11.pptx
PDF
EN-Survey-Report-SAP-LeanIX-EA-Insights-2025.pdf
PDF
Nekopoi APK 2025 free lastest update
PPTX
Transform Your Business with a Software ERP System
PPTX
Oracle E-Business Suite: A Comprehensive Guide for Modern Enterprises
PPTX
assetexplorer- product-overview - presentation
Agentic AI Use Case- Contract Lifecycle Management (CLM).pptx
Understanding Forklifts - TECH EHS Solution
PTS Company Brochure 2025 (1).pdf.......
medical staffing services at VALiNTRY
ai tools demonstartion for schools and inter college
Which alternative to Crystal Reports is best for small or large businesses.pdf
Embracing Complexity in Serverless! GOTO Serverless Bengaluru
history of c programming in notes for students .pptx
Wondershare Filmora 15 Crack With Activation Key [2025
Digital Systems & Binary Numbers (comprehensive )
L1 - Introduction to python Backend.pptx
top salesforce developer skills in 2025.pdf
Internet Downloader Manager (IDM) Crack 6.42 Build 41
Claude Code: Everyone is a 10x Developer - A Comprehensive AI-Powered CLI Tool
Computer Software and OS of computer science of grade 11.pptx
EN-Survey-Report-SAP-LeanIX-EA-Insights-2025.pdf
Nekopoi APK 2025 free lastest update
Transform Your Business with a Software ERP System
Oracle E-Business Suite: A Comprehensive Guide for Modern Enterprises
assetexplorer- product-overview - presentation
Ad

Angular from Zero to Mastery - Training (Intermediate)