Full Stack(Java)
Internship Report
 Submitted by
Name: M.Arun Siva REG.NO:312521104003
 In partial fulfillment for the award of the degree of
 BACHELOR OF ENGINEERING
 IN
 COMPUTER SCIENCE AND
 ENGINEERING
 T.J.INSTITUTE OF TECHNOLOGY
 KARAPAKKAM
 CHENNAI 600097
 ANNA UNIVERSITY
 CHENNAI 600025
 T.J.INSTITUTE OF TECHNOLOGY
 RAJIVGANDHISALAI,KARAPAKKAM,CHENNAI-600097
 ANNAUNIVERSITY,CHENNAI-600025
 BONAFIDECERTIFICATE
 Certified that this internship Full Stack Web
 Development by Retech Solutions PVT LTD is the
 bonafide work of Arun Siva.M who carried out the
 internship under my supervision.
SIGNATURE SIGNATURE
MS.D.EVANGELINE NESA PRIYA MR.MOHAMMADARSAD
HEAD OF THE DEPARTMENT CLASS INCHARGE
 Acknowledgement
 The success and final outcome of learning machine
 learning required a lot of guidance and assistance from
 many people and I am extremely privileged to have got
 this all along the completion of my course and flow of
 the projects.All that i have done is only due to such a
 supervision and assistance and I would not forget to
 thank them.
 (Signature of Student)
 Date:
 Table of Contents
 • Internship Certificate
 • Introduction
 • Overview
Day 1.Introduction to Full-Stack Web Development
  Distinguish between Back End, Front End and Full
 stack development
  Understanding the pre-requistieof Full stack
 Development
Day 2.
  Introduction of Programminglanguages
  Difference between MERN and MEAN
Day 3.Programming with Java script
  Understanding Javascriptand its basics
  History of Javascript
  Basic coding with Java script and ES6
Day 4.
  Fundamentals and data types in Javascript
  Understanding JSON
  Distinguish between JSON and AJAX
  Types of error handlings in Javascript
Day 5.Javascript in depth
  Running Java script on browser
  Distinguishbetween console and snippets
  Creating popupson browser
Day 6.
  Understanding different types of popups in browser
  Debugging the code using F12
Day 7.Programming with Java
  Understanding the basics of Java
  History of Java
  Understanding Java Virtual Machine(JVM) and Java
 Runtime environment
Day 8.
  Working with Intellij idea
  Features of java
  Understanding a simple Java code
Day 9.
  Fundamentals of Java
  Data types and Loops in Java
  Error handling
  Java in back end development
Day 10.HTML and CSS in depth
  Understanding Hyper text markup language
  Creating tags in html
  Understanding of HTML code in depth
  Basic designing of webpage using HTML
Day 11.
  About Cascading style sheets
  Importance of CSS in HTML or XML
  Create a simple layout using HTML5 and CSS
Day 12.Bootstrap
  Overview of Bootstrap(Introduction,Syntax)
  Basics of Bootstrap components
  Input types in Bootstrap
Day 13.
  Bootstrap advance components
  Creating a UI using Bootstrap
  Understandingthe basics of UI/UX designing
  Understanding the basics of React
Day 14.Mongo DB
  Overview of MongoDB
 • a.Introduction of MongoDB
 • b.No SQL Database
 • c.Advantage over RDBMS
 • d.MongoDB Data Types
 • e.MongoDB Data Modeling
 Understanding Mongo DB operators
Day 15.
  Database and Database commands in Mongo DB
 • a.Create Database
 • b.Drop Database
 • c.Create Collection
 • d.Drop Collection
  CRUD:Documents
Day 16.
  Mongo DB shell and Mongo DB tools
 • a.MongoDB Compass
 • b.MongoDB BI connector
  Understanding MongoDBcloud and connectivity
 • a.Java MongoDB
 • b.PHP MongoDB
 • c.Python MongoDB
Day 17.Node JS
  Overview of Node JS
  Node JS modulesa.Functionsb.Bufferc.Types of
 modules
Day 18.
  Node package manner
  Creating web servera.Sending requestsb.Handling
 HTTP request
Day 19
  File system
  Debugging Node JS application
Day 20.Express JS
  Introduction to Express JS
  Routing in Express JS
Day 21.
  Middle ware in Express JS
  Templating engines with Express JS
Day 22.
  Handling static files(CSS, javascript)
  Error handling
Day 23.React JS
  Introduction to React
 • a.Origin of React
 • b.React.js syntax
Day 24.
  React components
 • a.React component properties
 • b.Setting properties
 • c.Updating properties
 • d.Rendering react components
  Expression and attributes
Day 25.
  Creating a dynamic UI in React
  Integration with other Libraries
 • a.React with jQuery
 • b.React and AJAX
Day 26.
  Event handling in Reacta.Key eventsb.Event
 poolingc.React.js event handlersd.Synthetic event
Day 27.Angular JS
  Overview of Angular JS
 • a.Introduction
 • b.Setting up the environment
 • c.MVC architecture
 • d.Conceptual Overview
 • e.Understanding ng attributes
Day 28.
  Expressions and data binding
 • a.Number and String Expressions
 • b.Object biding and Expressions
 • c.Working with Arrays
 • d.Understanding data binding
Day 29.
  Working with Directivesa.Conditional Directivesb.Style
 directives
Day 30.
  Controllersand Filters
 • a.Understanding Controllers and Filters
 • b.Programming Controllers
 • c.Scope object
 • d.Adding Behaviour to a Scope Object
 • e.Passing Parameters to the Methods
 • f.Multiple Controllers and their scopes
 • g.Built-In Filters
 • h.Uppercase and Lowercase Filters
 • i.Currency and Number Formatting Filters
 • j.OrderBy Filter
 • k.Creating Custom Filter
 Modules and routing
 Introduction
HTML
 HTML is the standard markup language for creating Web pages.
What is HTML?
  HTML stands for Hyper Text Markup Language
  HTML is the standard markup language for creating Web pages
  HTML describes the structure of a Web page
  HTML consists of a series of elements
  HTML elements tell the browser how to display the content
  HTML elements label pieces of content such as "this is a heading", "this is
 a paragraph", "this is a link", etc.
<!DOCTYPE html>
<html>
<head>
<title>Page Title</title>
</head>
<body>
<h1>My First Heading</h1>
<p>My first paragraph.</p>
</body>
</html>
Example Explained
  The <!DOCTYPE html> declaration defines that this document is an
 HTML5 document
  The <html> element is the root element of an HTML page
  The <head> element contains meta information about the HTML page
  The <title> element specifies a title for the HTML page (which is shown
 in the browser's title bar or in the page's tab)
  The <body> element defines the document's body, and is a container for
 all the visible contents, such as headings, paragraphs, images, hyperlinks,
 tables, lists, etc.
  The <h1> element defines a large heading
  The <p> element defines a paragraph
  An HTML element is defined by a start tag, some content, and an end tag:
  <tagname> Content goes here... </tagname>
  The HTML element is everything from the start tag to the end tag:
  <h1>My First Heading</h1>
  <p>My first paragraph.</p>
 Start tag Element content End tag
 <h1> My First Heading </h1>
 <p> My first paragraph. </p>
 <br> none none
What Is Web Development?
  Web development is the process of creating a website on the
 internet. Web development refers to the non-design aspects of a
 website, such as creating features and functionality using
 programming, markup, and scripting languages. Developers
 concentrate on the technical aspects of website development,
 such as architecture, programming, and application integration,
 and graphics.
Types of Web Development
  Web development mainly includes frontend development,
 backend development, and when the two are put together,
 there is Fullstack development.
 Distinguish between Back End, Front End and Full
 stack development
Frontend Development
  The aspect of web development that codes and produces
 frontend elements of a website, or features that are immediately
 observable and accessible by the end-user or client, is known
 as frontend development.
  Essentially, a frontend developer is in charge of everything you
 see be it styling, graphics, text, alignment, navigation, colors, and
 so on, and attempts to improve the user experience to make it as
 seamless as possible.
 They also contribute to the overall design and aesthetic, along
 with debugging.
 The major goals of frontend development are responsiveness and
 performance
Backend Development
  Web development that occurs at the back end of programs is
 accurately termed backend development.
  backend development covers server-side web application logic
 and integration, and activities, like writing APIs, creating libraries,
 and working with system components as opposed to frontend
 development, which focuses on customer-facing services and
 programs.
  backend developers create code that allows a database and an
 application to communicate with one another.
  backend developers are in charge of the back end of a website,
 which includes servers, databases, and apps. They are in control
 of what you don't see.
Full Stack Development
  An individual who operates on the front end and back end of a
 web - based application is known as a full stack developer. While
 the back end is in charge of the site's architecture and logic in the
 background, the front end is in charge of the website's aesthetic
 appearance and feel.
Full Stack Development Front End Developer Back End Developer
Able to create both sides Is incharge of
 Is incharge of the client-side
of a website server side
A frontend technology, Ruby, PHP,
 Knowledge of HTML/CSS,
along with at least one Node.js, Java,
 React, Vue.js, and Angular
backend language Python, etc.
Complete lifecycle of a Improves the program's Database
web application usability and aesthetic management
MERN Stack
 It is a popular web development technology stack consisting of four
 key components: MongoDB, Express.js, React.js, and Node.js. MERN
 supports the development of full-stack web applications and enables
 clients to seamlessly interact with the server
MERN Components
The four components of the MERN stack play a distinct role in building
dynamic and scalable web applications.
MongoDB (M)
 MongoDB is a NoSQL database in which we can store data in a
 flexible JSON-like format also known as BSON (Binary JSON). This
 database is capable of handling large amounts of data and provides
 scalability and high performance..
Express.js (E)
 Express.js is a minimal and flexible Node.js web application
 framework that simplifies the process of building robust and scalable
 server-side applications.
React.js (R)
 React.js is a JavaScript library for building user interfaces. Developed
 by Facebook, it allows developers to create reusable UI components
 that update efficiently and quickly based on data changes.
Node.js (N)
 Node.js is a runtime environment that executes JavaScript code on
 the server side. It enables developers to use JavaScript for both
 client and server-side development, promoting code consistency.
MEAN Stack
 The MEAN Stack is a popular web development technology stack
 that consists of four main components: MongoDB (a NoSQL
 database), Express.js (a web application framework), Angular (a
 front-end JavaScript framework), and Node.js (a runtime
 environment for server-side JavaScript). MEAN enables the
 development of full-stack web applications, utilizing JavaScript
 throughout the entire application stack.
MEAN Components
MongoDB (M)
 A NoSQL database that stores data in a flexible, JSON-like format.
 MongoDB is designed for scalability and facilitates efficient handling
 of large volumes of data.
Express.js (E)
 A minimalistic web application framework for Node.js, Express
 simplifies backend development by providing tools for routing,
 middleware, and handling HTTP requests.
Angular (A)
 A front-end framework developed by Google, Angular allows
 developers to build dynamic and interactive user interfaces. It
 follows a component-based architecture and supports two-way data
 binding.
Node.js (N)
 A runtime environment for executing server-side JavaScript, Node.js
 enables the development of scalable and high-performance server
 applications. It complements Express.js in building the backend of
 MEAN applications.
JavaScript
 1. JavaScript is the world's most popular programming language.
 2. JavaScript is the programming language of the Web.
 3. JavaScript is easy to learn.
Sample:
<!DOCTYPE html>
<html>
<body>
<h2>My First JavaScript</h2>
<button type="button"
onclick="document.getElementById('demo').innerHTML = Date()">
Click me to display Date and Time.</button>
<p id="demo"></p>
</body>
</html>
JavaScript Can Change HTML Content
One of many JavaScript HTML methods is getElementById().
The example below "finds" an HTML element (with id="demo"), and changes the
element content (innerHTML) to "Hello JavaScript":
document.getElementById("demo").innerHTML = "Hello JavaScript";
JavaScript Where To
<script>
document.getElementById("demo").innerHTML = "My First JavaScript";
</script>
JavaScript Values
The JavaScript syntax defines two types of values:
  Fixed values
  Variable values
Fixed values are called Literals.
Variable values are called Variables.
JavaScript Literals
The two most important syntax rules for fixed values are:
1. Numbers are written with or without decimals:
10.50
1001
2. Strings are text, written within double or single quotes:
"John Doe"
'John Doe'
JavaScript Variables
In a programming language, variables are used to store data values.
JavaScript uses the keywords var, let and const to declare variables.
An equal sign is used to assign values to variables.
In this example, x is defined as a variable. Then, x is assigned (given) the value 6:
let x;
x = 6;
JavaScript Operators
JavaScript uses arithmetic operators ( + - * / ) to compute values: (5 + 6) * 10
JavaScript uses an assignment operator ( = ) to assign values to variables:
let x, y;
x = 5;
y = 6;
JavaScript Functions
A JavaScript function is a block of code designed to perform a particular task.
A JavaScript function is executed when "something" invokes it (calls it).
// Function to compute the product of p1 and p2
function myFunction(p1, p2) {
 return p1 * p2;
}
Function Invocation
The code inside the function will execute when "something" invokes (calls) the
function:
 • When an event occurs (when a user clicks a button)
  When it is invoked (called) from JavaScript code
  Automatically (self invoked)
Function Return
 When JavaScript reaches a return statement, the function will stop executing.
 If the function was invoked from a statement, JavaScript will "return" to execute the code after the
 invoking statement.
 Functions often compute a return value. The return value is "returned" back to the "caller":
// Function is called, the return value will end up in x
let x = myFunction(4, 3);
function myFunction(a, b) {
// Function returns the product of a and b
 return a * b;
}
JavaScript Objects
In real life, objects are things like: houses, cars, people, animals, or any other subjects.
Object Properties
 A real life car has properties like weight and color:
car.name = Fiat, car.model = 500, car.weight = 850kg, car.color = white.
 Car objects have the same properties, but the values differ from car to car.
Object Methods
 A real life car has methods like start and stop:
car.start(), car.drive(), car.brake(), car.stop().
 Car objects have the same methods, but the methods are performed at
 different times.
JavaScript Variables
JavaScript variables are containers for data values.
This code assigns a simple value (Fiat) to a variable named car: let car = "Fiat";
JavaScript Objects
Objects are variables too. But objects can contain many values.
This code assigns many values (Fiat, 500, white) to an object named car:
const car = {type:"Fiat", model:"500", color:"white"};
JavaScript Object Literal
An object literal is a list of name:value pairs inside curly braces {}.
{firstName:"John", lastName:"Doe", age:50, eyeColor:"blue"}
JSON
JSON stands for JavaScript Object Notation
JSON is a text format for storing and
transporting data
JSON is "self-describing" and easy to understand
What is JSON?
  JSON stands for JavaScript Object Notation
  JSON is a lightweight data-interchange
 format
  JSON is plain text written in JavaScript object
 notation
  JSON is used to send data between
 computers
  JSON is language independent
What is Java?
 Developed by Sun Microsystems in 1995, Java is a highly popular,
 object-oriented programming language. This platform independent
 programming language is utilized for Android development, web
 development, artificial intelligence, cloud applications, and much
 more.
Java Virtual Machine
 JVM(Java Virtual Machine) runs Java applications as a run-time
 engine. JVM is the one that calls the main method present in a
 Java code. JVM is a part of JRE(Java Runtime Environment).
 Java applications are called WORA (Write Once Run Anywhere).
 This means a programmer can develop Java code on one system
 and expect it to run on any other Java-enabled system without any
 adjustment. This is all possible because of JVM.
Java Runtime Environment
 Java Runtime Environment (JRE) is an open-access software
 distribution that has a Java class library, specific tools, and a
 separate JVM. In Java, JRE is one of the interrelated components in
 the Java Development Kit (JDK). It is the most common
 environment available on devices for running Java programs. Java
 source code is compiled and converted to Java bytecode.
Components of Java JRE
The components of JRE are mentioned below:
  Integration libraries include Java Database Connectivity (JDBC )
  Java Naming, Interface Definition Language (IDL)
  Directory Interface (JNDI)
  Remote Method Invocation Over Internet Inter-Orb Protocol
 (RMI-IIOP)
  Remote Method Invocation (RMI)
  Scripting
CSS
CSS stands for Cascading Style Sheets.
CSS saves a lot of work. It can control the
layout of multiple web pages all at onc
What is CSS?
Cascading Style Sheets (CSS) is used to format the layout of a webpage.
With CSS, you can control the color, font, the size of text, the spacing
between elements, how elements are positioned and laid out, what
background images or background colors are to be used, different
displays for different devices and screen sizes, and much more!
Using CSS
CSS can be added to HTML documents in 3 ways:
  Inline - by using the style attribute inside HTML elements
  Internal - by using a <style> element in the <head> section
  External - by using a <link> element to link to an external CSS file
The most common way to add CSS, is to keep the styles in external
CSS files. However, in this tutorial we will use inline and internal
styles, because this is easier to demonstrate, and easier for you to try
it yourself.
Inline CSS
An inline CSS is used to apply a unique style to a single HTML element.
An inline CSS uses the style attribute of an HTML element.
The following example sets the text color of the <h1> element to blue,
and the text color of the <p> element to red:
Example
<!DOCTYPE html>
<html>
<body>
<h1 style="color:blue;">A Blue Heading</h1>
<p style="color:red;">A red paragraph.</p>
</body>
</html>
Internal CSS
An internal CSS is used to define a style for a
single HTML page.
An internal CSS is defined in the <head> section of an HTML page,
within a <style> element.
The following example sets the text color of ALL the <h1> elements (on
that page) to blue, and the text color of ALL the <p> elements to red. In
addition, the page will be displayed with a "powderblue" background
color:
Example
<!DOCTYPE html>
<html>
<head>
<style>
body {background-color: powderblue;}
h1 {color: blue;}
p {color: red;}
</style>
</head>
<body>
<h1>This is a heading</h1>
<p>This is a paragraph.</p>
</body>
</html>
External CSS
An external style sheet is used to define the style for many HTML pages.
To use an external style sheet, add a link to it in the <head> section of
each HTML page:
Example
<!DOCTYPE html>
<html>
<head>
 <link rel="stylesheet" href="styles.cs
s">
</head>
<body>
<h1>This is a heading</h1>
<p>This is a paragraph.</p>
</body>
</html>
"styles.css":
body {
 background-color: powderblue;
}
h1 {
 color: blue;
}
p {
 color: red;
Bootstrap
What is Bootstrap?
  Bootstrap is a free front-end framework for faster and
 easier web development
  Bootstrap includes HTML and CSS based design templates
 for typography, forms, buttons, tables, navigation, modals,
 image carousels and many other, as well as optional
 JavaScript plugins
  Bootstrap also gives you the ability to easily create
 responsive designs
Bootstrap History
Bootstrap was developed by Mark Otto and Jacob Thornton at
Twitter, and released as an open source product in August 2011
on GitHub.
In June 2014 Bootstrap was the No.1 project on GitHub!
Why Use Bootstrap?
Advantages of Bootstrap:
  Easy to use: Anybody with just basic knowledge of HTML
 and CSS can start using Bootstrap
  Responsive features: Bootstrap's responsive CSS adjusts to
 phones, tablets, and desktops
  Mobile-first approach: In Bootstrap 3, mobile-first styles
 are part of the core framework
  Browser compatibility: Bootstrap is compatible with all
 modern browsers (Chrome, Firefox, Internet Explorer,
 Edge, Safari, and Opera)
Where to Get Bootstrap?
There are two ways to start using Bootstrap on your own web
site.
You can:
  Download Bootstrap from getbootstrap.com
  Include Bootstrap from a CDN
Bootstrap Versions
 This tutorial follows Bootstrap 3, which was released in 2013.
 However, we also cover newer versions; Bootstrap 4
 (released 2018) and Bootstrap 5 (released 2021).
 Bootstrap 5 is the newest version of Bootstrap; with new
 components, faster stylesheets, more responsiveness etc. It
 supports the latest, stable releases of all major browsers and
 platforms. However, Internet Explorer 11 and down is not
 supported.
 The main differences between Bootstrap 5 and Bootstrap 3 &
 4, is that Bootstrap 5 has switched to JavaScript instead
 of jQuery.
MongoDB
MongoDB is a document database. It stores data in a type of
JSON format called BSON.
A record in MongoDB is a document, which is a data structure
composed of key value pairs similar to the structure of JSON
objects.
A MongoDB Document
Records in a MongoDB database are called documents, and the
field values may include numbers, strings, booleans, arrays, or
even nested documents.
{
 title: "Post Title 1",
 body: "Body of post.",
 category: "News",
 likes: 1,
 tags: ["news", "events"],
 date: Date()
}
Node.js
What is Node.js?
  Node.js is an open source server environment
  Node.js is free
  Node.js runs on various platforms (Windows,
 Linux, Unix, Mac OS X, etc.)
  Node.js uses JavaScript on the server
Why Node.js?
 A common task for a web server can be to open a file on the
 server and return the content to the client.
 Here is how PHP or ASP handles a file request :
 1. Sends the task to the computer's file system.
 2. Waits while the file system opens and reads the file.
 3. Returns the content to the client.
 4. Ready to handle the next request.
 Here is how Node.js handles a file request:
 1. Sends the task to the computer's file system.
 2. Ready to handle the next request.
 3. When the file system has opened and read the file, the
 server returns the content to the client.
 Node.js eliminates the waiting, and simply continues with the
 next request.
 Node.js runs single-threaded, non-blocking, asynchronous
 programming, which is very memory efficient.
What Can Node.js Do?
  Node.js can generate dynamic page content
  Node.js can create, open, read, write, delete, and close
 files on the server
  Node.js can collect form data
  Node.js can add, delete, modify data in your database
What is a Node.js File?
  Node.js files contain tasks that will be executed on certain
 events
  A typical event is someone trying to access a port on the
 server
  Node.js files must be initiated on the server before having
 any effect
  Node.js files have extension ".js"
React
What is React?
React, sometimes referred to as a frontend
JavaScript framework, is a JavaScript library
created by Facebook.
React is a tool for building UI components.
How does React Work?
React creates a VIRTUAL DOM in memory.
Instead of manipulating the browser's DOM
directly, React creates a virtual DOM in memory,
where it does all the necessary manipulating,
before making the changes in the browser DOM.
React only changes what needs to be changed!
React finds out what changes have been made,
and changes only what needs to be changed.
React.JS History
Current version of React.JS is V18.0.0 (April
2022).
Initial Release to the Public (V0.3.0) was in July
2013.
React.JS was first used in 2011 for Facebook's
Newsfeed feature.
Facebook Software Engineer, Jordan Walke,
created it.
Current version of create-react-app is v5.0.1
(April 2022).
create-react-app includes built tools such as
webpack, Babel, and ESLint.
Express.js
 Express.js is a fast, flexible and minimalist web framework
 for Node.js. It's effectively a tool that simplifies building
 web applications and APIs using JavaScript on the server
 side. Express is an open-source that is developed and
 maintained by the Node.js foundation.
 Express.js offers a robust set of features that enhance your
 productivity and streamline your web application. It makes
 it easier to organize your application’s functionality with
 middleware and routing. It adds helpful utilities to Node
 HTTP objects and facilitates the rendering of dynamic HTTP
 objects.
Why learn Express?
Express is a user-friendly framework that simplifies the
development process of Node applications. It uses JavaScript
as a programming language and provides an efficient way to
build web applications and APIs. With Express, you can easily
handle routes, requests, and responses, which makes the
process of creating robust and scalable applications much
easier. Moreover, it is a lightweight and flexible framework
that is easy to learn and comes loaded with middleware
options. Whether you are a beginner or an experienced
developer, Express is a great choice for building your
application. To master Express.js and use it in full-stack
development, the Full Stack Development with React & Node
JS course covers everything from routing to middleware
integration
Key Features of Express
 1. Middleware and Routing: Define clear pathways (routes)
 within your application to handle incoming HTTP requests
 (GET, POST, PUT, DELETE) with ease. Implement reusable
 functions (middleware) to intercept requests and create
 responses, adding functionalities like authentication,
 logging, and data parsing.
 2. Minimalistic Design: Express.js follows a simple and
 minimalistic design philosophy. This simplicity allows you
 to quickly set up a server, define routes, and handle HTTP
 requests efficiently. It’s an excellent choice for building
 web applications without unnecessary complexity.
 3. Flexibility and Customization: Express.js doesn’t impose a
 strict application architecture. You can structure your
 code according to your preferences. Whether you’re
 building a RESTful API or a full-fledged web app, Express.js
 adapts to your needs.
 4. Templating Power: Incorporate templating engines like
 Jade or EJS to generate dynamic HTML content, enhancing
 user experience.
 5. Static File Serving: Effortlessly serve static files like
 images, CSS, and JavaScript from a designated directory
 within your application.
 6. Node.js Integration: Express.js seamlessly integrates with
 the core functionalities of Node.js, allowing you to
 harness the power of asynchronous programming and
 event-driven architecture.
Applications of Express
Express.js empowers you to construct a wide array of web
applications. Here are some captivating examples:
  RESTful APIs: Develop robust APIs that adhere to the REST
 architectural style, enabling communication with other
 applications and front-end interfaces.
  Real-time Applications: Leverage Express.js's event-
 driven nature to create real-time applications like chat or
 collaborative editing tools.
  Single-Page Applications (SPAs): Craft SPAs that fetch and
 update content dynamically on the client-side, offering a
 seamless user experience .
AngularJS
 AngularJS is a JavaScript framework. It can be added to an
 HTML page with a <script> tag.
 AngularJS extends HTML attributes with Directives, and binds
 data to HTML with Expressions
AngularJS is a JavaScript Framework
 AngularJS is a JavaScript framework written in JavaScript.
 AngularJS is distributed as a JavaScript file, and can be added
 to a web page with a script tag:
<script src="https://ajax.googleapis.com/
ajax/libs/angularjs/1.6.9/
angular.min.js"></script>
AngularJS Extends HTML
 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.
<!DOCTYPE html>
<html>
<script
src="https://ajax.googleapis.com/ajax/libs/angularjs/1.6.9/angula
r.min.js"></script>
<body>
<div ng-app="">
<p>Input something in the input box:</p>
<p>Name: <input type="text" ng-model="name"></p>
<p ng-bind="name"></p>
</div>
</body>
</html>
Example explained:
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 content of the
<p> element to the application variable name.
AngularJS Directives
 As you have already seen, AngularJS directives are HTML
 attributes with an ng prefix.
 The ng-init directive initializes AngularJS application
 variables.
<!DOCTYPE html>
<html>
<script
src="https://ajax.googleapis.com/ajax/libs/angularjs/1.6.9/angula
r.min.js"></script>
<body>
<div ng-app="" ng-init="firstName='John'">
<p>The name is <span ng-bind="firstName"></span></p>
</div>
</body>
</html>
AngularJS Expressions
 AngularJS expressions are written inside double
 braces: {{ expression }}.
 AngularJS will "output" data exactly where the expression is
 written:
<!DOCTYPE html>
<html>
<script
src="https://ajax.googleapis.com/ajax/libs/angularjs/1.6.9/angula
r.min.js"></script>
<body>
<div ng-app="">
<p>My first expression: {{ 5 + 5 }}</p>
</div>
</body>
</html>
AngularJS Applications
 AngularJS modules define AngularJS applications.
 AngularJS controllers control AngularJS applications.
 The ng-app directive defines the application, the ng-
 controller directive defines the controller
<!DOCTYPE html>
<html>
<script
src="https://ajax.googleapis.com/ajax/libs/angularjs/1.6.9/angula
r.min.js"></script>
<body>
<p>Try to change the names.</p>
<div ng-app="myApp" ng-controller="myCtrl">
First Name: <input type="text" ng-model="firstName"><br>
Last Name: <input type="text" ng-model="lastName"><br>
<br>
Full Name: {{firstName + " " + lastName}}
</div>
<script>
var app = angular.module('myApp', []);
app.controller('myCtrl', function($scope) {
 $scope.firstName= "John";
 $scope.lastName= "Doe";
});
</script>
</body>
</html>
AngularJS modules define applications:
ar app = angular.module('myApp', []);
AngularJS controllers control applications:
app.controller('myCtrl', function($scope)
{
 $scope.firstName= "John";
 $scope.lastName= "Doe";
});