AngularJS
What is it?
-
AngularJS is a JavaScript framework for building MVC based application.
-
It is a library written in JavaScript.
-
It is a made for Single-Page-Application (SPA).
data:image/s3,"s3://crabby-images/c4f33/c4f3393744319295afd8d3b576ad3c21c953a121" alt=""
-
It extends HTML attributes with Directives and binds data to HTML with Expressions.
-
AngularJS is distributed as a JavaScript file, and can be added to a web page with a <script> tag:
Why AngularJS?
It supports MVC:
-
This pattern is based on splitting the business logic layer, the data layer, and presentation layer into separate sections.
-
So that each one could be managed more easily.
Data Model Binding:
-
We don't need to write special code to bind data to HTML controls.
Writing Less Code:
-
With AngularJS, lesser amount of code we need to write for DOM manipulation.
Hello World
Environment Setup
-
To work with AngularJS, we need to set-up environment for this HTML page.​
-
Get the CDN or the .js file to make the link to the AngularJS code from https://angularjs.org/.
data:image/s3,"s3://crabby-images/fe7b6/fe7b66f694345f52dda0640c9ae872a13fd84b42" alt=""
Copy that CDN for Internet link
Download AngularJS file
OR
-
We have two ways to set the AngularJS file bind with the page.
-
Link CDN from Internet
data:image/s3,"s3://crabby-images/5553c/5553c900fb19d771c190ed1cb58d35c26f26e7e8" alt=""
Set the CDN link with the <script> tag.
-
From Local
data:image/s3,"s3://crabby-images/300b0/300b057d2a1a09e4372f50d4846d3d7cf1f64c45" alt=""
Set the physical path of the angular.js file from Local Computer.
First Application
-
After linking with the AngularJS file with the HTML page, we must use ng-app directive, where we want to put AngularJS code in HTML.
-
Here we make an AngularJS application.
-
We can use the expression inside double-curly-braces ( {{ }} ).​
data:image/s3,"s3://crabby-images/d3c3e/d3c3e0396b0c24ff4a0590a25f358fe98ee8aa37" alt=""
-
AngularJS extends HTML with ng-directives.
-
The ng-app directive defines an AngularJS application.
-
The ng-model directive binds the value of HTML controls (input, select, textarea) to application data.
-
The ng-bind directive binds application data to the HTML view.
-
Here is the Hello, World! program of the AngularJS.
data:image/s3,"s3://crabby-images/16e16/16e1637897b87f1d7f57c3a51d243cb1537151cb" alt=""
-
AngularJS starts automatically when the web page has loaded.
-
The ng-app directive tells AngularJS that the <div> element is the "owner" of an AngularJS application.
-
The ng-model directive binds the value of the input field to the application variable name.
-
The ng-bind directive binds the innerHTML of the <p> element to the application variable name.
AngularJS Modules
-
AngularJS supports modular approach.
-
It is used to separate logics such as; application, controller, services etc.
-
We can keep the modules different .js file.
-
Here we will create 2 modules.
index.html
<html>
​
<script src="myApp.js">
<script>
​
<script src="controller.js">
<script>
​
​
​
​
​
​
<html>
mainApp.js
var myApp = angular.module("myApp", [ ]);
controller.js
myApp.controller("studentController", function($scope) {
$scope.var = "alok";
​
} ) ;
HTML Page
Application Module
Controller Module
Application Module
-
It used to initialize an application with the controller(s).
-
We declare an application myApp module using angular.module( ) function.
Controller Module
-
It used to define the controller.
-
We declare a controller module using myApp.controller( ) function.
-
Here we've used application module using ng-app directive and controller using ng-controller directive.
-
We've imported myApp.js and c ontroller.js in the main HTML page.
Directives
-
AngularJS directives are used to extend HTML.
-
These are special attributes starting with ng- prefix.
-
AngularJS comes with the set of predefined directives.
-
Developers can create custom directives.
-
Here are some important AngularJS directives in below table.
Filters
-
It is used to modify or change data representation in AngularJS.
-
Also can be used to specify search criteria.
-
Can be used with expression.
-
Filters are used after a pipeline ' | '.
-
Here are some predefined filters in AngularJS.
-
Here is an example of filters in AngularJS.
-
We have 2 files, a filter.html and a filter.js file.
-
Below is the filter.js file.
data:image/s3,"s3://crabby-images/248ce/248ce6ebfacf5b2bc20e3a4a3efce1a1e10e67d9" alt=""
-
Below is the filter.html file.​
data:image/s3,"s3://crabby-images/a5db6/a5db6c85af00f10654cd4eac32a4fe4bcfc7d4a3" alt=""
-
Here the html looks in a browser.
-
We can filter by entering the searching field.
data:image/s3,"s3://crabby-images/368bf/368bff8872d2a82b14ae459ff6f55dcf3d665439" alt=""
uppercase
lowercase
no filter
currency
search filter
-
In a single table, we can make multiple search filters.
-
Here we made 3 input text field, where we bind all 3 variable with search and gave to filter parameter.
data:image/s3,"s3://crabby-images/96641/966415206d3e1772b2b76518fa83a2f41763d171" alt=""
Form Validation
-
AngularJS improves form filling and validation.
-
We can use ng-click to handle AngularJS button and $dirty, $invalid, and $error to the validation.
-
AngularJS provides multiple events which can be associated with buttons.
-
Followings are supported events we can use in the <button> tag.
-
ng-click
-
ng-dbl-click
-
ng-mousedown
-
ng-mouseup
-
ng-mouseover
-
ng-mouseleave
-
ng-mousemove
-
ng-keyup
-
ng-keydown
-
Followings are used to track the error.
-
$dirty: States the value has been changed.
-
$invalid: States that value entered is invalid.
-
$error : State exact error.
-
Here is the example of a Form Validation application using AngularJS.
-
Some CSS is used to decorate the page, not shown in below picture.
-
Below picture shows the HTML page of below application.
data:image/s3,"s3://crabby-images/de94f/de94f596de647c02694b59e7b97721adb9c200c3" alt=""
-
The javascript file is given below.
-
Here we have a reset( ) function, where it clears the 3 text fields.
data:image/s3,"s3://crabby-images/722ac/722acabe4e9bb926858d5215ae62776102ec1794" alt=""
-
The form validation page looks like below.
-
Here two buttons for reset and submit.
-
The text fields are to be valid show the Submit button.
data:image/s3,"s3://crabby-images/fbc42/fbc428682b4b06b9752c5aaeae44f09cf196a9fb" alt=""
Includes
-
Using AngularJS, we can embed HTML pages within an HTML page using ng-include directive.
-
Here is the example of a 2 embedded HTML page within a page.
data:image/s3,"s3://crabby-images/c379b/c379be6a6b805d9580f91e78ef4e967dccb18a6f" alt=""
page1.html
page2.html
AJAX
-
AngularJS provides $https: control which works as a service to read data from the server.
-
The server makes a database call to get the desired records.
-
AngularJS needs data in JSON format.
-
Here is a example of AJAX using AngularJS.
-
We have 3 files:
-
data.txt (JSON data)
-
ajax.html
-
ajax.js
-
This below picture is the json object in a txt file.
data:image/s3,"s3://crabby-images/1b480/1b48058c62aa46036e7f657cf7efe5d5db0a6a2e" alt=""
-
Here is the ajax.html page.
-
It has a table getting the data from data.txt file through AJAX.
data:image/s3,"s3://crabby-images/39f6d/39f6d4ec9a1abc55ec6bfce4a47413a08b49307e" alt=""
-
We used a $http service along with $scope service.
-
$http service makes a request to the server, and returns a response.
-
This service has several methods:
-
.delete()
-
.get()
-
.head()
-
.hsonp()
-
.patch()
-
.post()
-
.put()
-
$http.get() reads the JSON data from data.txt file. Here is the ajax.js file.
data:image/s3,"s3://crabby-images/98ed7/98ed7dedf45f066ce47a77c5591c60643443179b" alt=""
-
Below picture is the table got the data from JASON file using AJAX technic.
data:image/s3,"s3://crabby-images/30c48/30c48f0c757e13fdeebc1b3566b5f96a453392d1" alt=""
View / Page Routing
-
AngularJS supports Single Page Application via multiple views on a single page.
-
To do this AngularJS has provided ng-view and ng-template directives and $routeProvider services.
-
We need to add the angular-route.js file to work with these $routeProvider services.
-
JS application needs a dependency injection.
-
ng-view:
-
creates a place holder where a corresponding view (HTML or ng-template view) can be placed based on the configuration.
-
ng-template
-
used to create an HTML view using script tag.
-
It contains "id" attribute which is used by $routeProvider to map a view with a controller.
-
$routeProvider
-
is the key service which set the configuration of URLs, map them with the corresponding html page or ng-template, and attach a controller with the same.
-
This below picture is the main HTML page routing.html.
-
This page contains a container which will show either of 2 links; showProduct.html & showService.html.
data:image/s3,"s3://crabby-images/f6e46/f6e460a1fa7790c74bc4b3052b150d50680e39ea" alt=""
-
$routeProvider.when defines a url "/addStudent" which then is mapped to "addStudent.htm".
-
"otherwise" is used to set the default view.
-
Here is the .js file; routing.js.
data:image/s3,"s3://crabby-images/9e7b6/9e7b63c27d6dcd8b999b9ef073f0fa389e656ff7" alt=""
-
This is the result when we open the routing.html page.
-
Main html page contains 2 HTML page.
data:image/s3,"s3://crabby-images/2ffe8/2ffe8fc4fafd1440de84890ded497a10133f490a" alt=""
id changes
HTML content changes
showProduct.html
or
showService.html
Services
-
In AngularJS, a service is a function, or object, that is available for, and limited to, your AngularJS application.
-
Services are normally injected using dependency injection mechanism
-
AngularJS has about 30 built-in services.
-
$location: Return information about the location of the current web page
-
$http: To make a request to the server & uses AJAX.
-
$timeout: Angular's version of the window.setTimeoutfunction.
-
$interval​: Angular's version of the window.setIntervalfunction.
-
$rout: Used to define routing imformation.
-
etc..
Custom Services
-
In AngularJS, we can make our own services.
-
Controllers & filters can call them as on requirement basis.
-
There are 2 steps to create custom service.
-
using factory method (optional)
-
using service method
Step 1: Using factory method (optional)
-
Using factory method, we first define a factory and then assign a method to it.
data:image/s3,"s3://crabby-images/d8adc/d8adc0a82b43b136422c41797216a413d8fc09b8" alt=""
create factory method
Step 2: Using service method
-
Using factory method, we first define a factory and then assign a method to it.
data:image/s3,"s3://crabby-images/92e31/92e311dd6bf0d8ed53b45e1f7698d3e373c2e420" alt=""
create a service
-
Using factory method, we first define a factory and then assign a method to it.
data:image/s3,"s3://crabby-images/e6b10/e6b10d97912258a99c591907b1bdf292418f9895" alt=""
no factory method
create a service
use that service on the controller
Step 3: Write the code in the editor.
-
Write the .js file, where we creates an app, factory method, service method, and use that service method in the controller.
data:image/s3,"s3://crabby-images/a31b5/a31b58abf97f7ed8edc520e49dfb6c2e5ebf88e1" alt=""
create a service
create factory method
create application module
use that service
-
The HTML page contains the angular.min.js, customService.js file.
-
The button calls the square( ) function.
data:image/s3,"s3://crabby-images/f3ac3/f3ac30af5fcf7f2c907eed2f05a0a87b9b1dc5c4" alt=""
-
Here is the costumService.html page looks like in a browser.
data:image/s3,"s3://crabby-images/8efb0/8efb0448764d85dd105676ccc566ef203c4b21a4" alt=""
Dependency Injection
-
It is a design pattern in which component are given their dependencies instead of hardcoding them within the component.
-
This helps in making components reusable, maintainable and testable.
-
It provides following core components for dependency injection.
-
value
-
factor
-
service
-
service
-
provider
-
constant​
value( ):
-
It is a javascript object and it is used to pass values to the controller during config phase.
data:image/s3,"s3://crabby-images/86963/8696302682f07d85147c96ce1f491e1627bb19bf" alt=""
factory( ):
-
It creates a value on demand whenever a service or controller requires.
-
It uses a factory function to calculate and return the value.
data:image/s3,"s3://crabby-images/990cc/990cc5f440982b23737944d57bb2c11583bf795c" alt=""
Create a factory "MathService"
service( ):
-
service is a singleton javascript object containing a set of functions to perform certain tasks.
-
Services are defined using service() functions and then injected into controllers.
data:image/s3,"s3://crabby-images/0545e/0545e3fcaa4ec15624ba146490e804f0a3365fea" alt=""
provider( ):
-
Provider is used by AngularJS internally to create services, factory etc.
-
Provider is a special factory method with a method get() which is used to return the value/service/factory.
data:image/s3,"s3://crabby-images/90093/900930ba6c8faa6d1767d8a2dc4b654d6fc630f7" alt=""
constant
-
Constants are used to pass values at config phase.
-
Syntax: mainApp.constant("configParam", "constant value");
Custom Directives
-
It extends HTML functionality.
-
A custom directive simply replaces the element for which it is activated.
-
AngularJS provides support to create custom directives for following type of elements.
-
Element directives- Directive activates when a matching element is encountered.
-
Attribute- Directive activates when a matching attribute is encountered.
-
CSS- Directive activates when a matching css style is encountered.
-
Comment- Directive activates when a matching comment is encountered.
-
Here is the custom elements we can use.
data:image/s3,"s3://crabby-images/0dbff/0dbff2cef3112247cfebd07cfbd574f715453fa1" alt=""
-
The angularJS file contains some steps to create custom directives.
-
First we need to create the initiate a a custom directive.
-
Then mention the restrict & template link.
data:image/s3,"s3://crabby-images/0fe7f/0fe7fcef353d0f2cb3fed9925512a49b78395c0f" alt=""
Internationalization
-
Internationalization (i18n) is the process of developing products in such a way that they can be localized for languages and cultures easily.
-
AngularJS supports inbuilt internationalization; three types of filters :
-
currency
-
date
-
& numbers.
-
To achive this features, we need to include the corresponding js according to the India locale of the country.
-
We need to get the Locale js file from AngularJS official site.​
-
Download js file or use the link.
data:image/s3,"s3://crabby-images/133bd/133bddff4cc6bdb3e15f7aa2ae8f73dca902ede6" alt=""
Download the Locale js file
-
To achive this features, we need to include the corresponding js according to the India locale of the country.
-
We need to get the Locale js file from AngularJS official site.​
-
Download js file or use the link.
data:image/s3,"s3://crabby-images/094a2/094a2dfb3903f4a159ffab99a0323188a4226eb6" alt=""
Locale .js file
-
Here is the locale file effect on the browser.
data:image/s3,"s3://crabby-images/a6ffe/a6ffe78e5d493cd29be74baa912e528b0f423b25" alt=""
Default Locale (USA)
India Locale
after including locale .js file