0% found this document useful (0 votes)
33 views

Introduction To ExpressJS

Uploaded by

Kanika Jain
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
33 views

Introduction To ExpressJS

Uploaded by

Kanika Jain
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 28

Introduction to ExpressJS

Agenda
● Introduction to ExpressJS
● Install ExpressJS
● ExpressJS – First Program
● Building Application Stack
● Express Routing
● Express Middleware
Introduction to ExpressJS
● Express is a web application framework for Node.
● It is a server-side or back-end framework not comparable to client-side frameworks like React, and
Angular but can be used in combination to build full-stack applications.
● Express is a fast, unopinionated, and minimalist web framework for Node.js.
● Building web applications with Node.js is MUCH easier.
● Used for both server-rendered apps as well as APIs.
● Full control of request and response.
● Most popular framework for Node.
● Great to use with client-side frameworks as it’s all JavaScript.
Prerequisites
● JS fundamentals ( Objects, Arrays, Conditions etc)
● Basic Node.js and NPM
● HTTP status codes
● JSON
Basic Server Syntax
Basic Route Handling
● Handling requests/route is simple.
● app.get(), app.post(), app.put(), app.delete() etc.
● Access to params, query string, url parts, etc
● Express has routers so we can store routes in separate files and export.
● We can parse incoming data with Body Parser.
Install Express JS
● Prerequisite: Node.js installed on the system.
● Visit the website for installation of node.js http://nodejs.org/en
● Assuming you’ve already installed Node.js.
● Create a directory to hold your application, and make that as your working directory.
Install Express JS
● Use the npm init command to create a package.json file for your application.
● This command prompts you for a number of things, such as the name and version of your application.
Hit RETURN to accept the default settings.
● For more information on how package.json works, see specifics of npm’s package.json handling.
Install Express JS
Install Express JS
● The package.json file for your application is as shown below.
● Used nodepad++ text editor
Install Express JS
● Use the npm i express command to install express
Install Express JS
● Create a myapp.js file in the root folder of express.
Express JS – First Program
● First program to print Hello World using express js.
Express JS – First Program
● We can check the output on any browser by using the url: http://localhost/5000.
Building Application Stack
● What is MERN Stack?
● A stack is the mixture of technologies used to create Web applications.
● Any web application will be made utilizing various technologies like (frameworks, libraries, databases).
● The MERN stack is a JavaScript stack that is intended to make the Application Development process
smoother.
Building Application Stack
● MERN Stack Components:
● MERN incorporates four open-source components:
○ MongoDB,
○ Express,
○ React, and
○ Node.js.
● These components give an end to end frameworks for developers to work with.
Building Application Stack
● Components Overview:
● MongoDB A document-oriented, No-SQL database used to store the application data.
● NodeJS: The JavaScript runtime environment. Used to run JavaScript on a machine rather than in a
browser.
● ExpressJS: A framework layered on top of NodeJS, used to build the backend of a site using NodeJS
functions and structures.
● ReactJS: A library created by Facebook. It is used to build UI components that create the user interface
of the single-page web application.
Building Application Stack
● Benefits of MERN Stack
● Javascript is the programming language utilized both for client-side and server-side.
● For tech stack with different programming languages, developers need to find out how to interface
them together. With the JavaScript stack, developers should be proficient in JavaScript and JSON.
● Using the MERN stack enables developers to build highly efficient web applications.
ExpressJS Routing
● Routing refers to the mechanism for serving the client the content it has asked for.
● It is the most important aspects of your website or web services.
● Routing in Express is simple, flexible, and robust.
● A route specification consists of
○ An HTTP method (GET, POST, etc.),
○ A path specification that matches the request URI,
○ And the route handler.
● The handler is passed in a request object and a response object.
● The request object can be inspected to get the various details of the request, and
● The response object’s methods can be used to send the response to the client
Routing – Request Objects
● To access a parameter value we use req.params.
○ req.param(name [, defaultValue])

● req.query: This holds a parsed query string.


○ It’s an object with keys: as the query string parameters and
○ Values as the query string values.
○ Multiple keys with the same name are converted to arrays, and
○ Keys with a square bracket notation result in nested objects
○ (e.g., order[status]=closed can be accessed as req.query.order.status).
Routing – Request Objects
● req.header, req.get(header):
○ The get method gives access to any header in the request.
○ The header property is an object with all headers stored as key-value pairs.

● req.path: The path for which the middleware function is invoked; can be any of:
○ A string representing a path.
○ A path pattern.
○ A regular expression pattern to match paths.
○ An array of combinations of any of the above.
Routing – Request Objects
● req.url, req.originalURL:
○ Contain the complete URL, including the query string.
○ If any middleware modifies the request URL, originalURL retains the original URL as it was received,
before the modification.

● req.body:
○ Contains key-value pairs of data submitted in the request body.
○ By default, it is undefined and is populated when you use body-parsing middleware is installed to
read and optionally interpret or parse the body.
Routing – Response Objects
● The res object represents the HTTP response that an Express app sends when it gets an HTTP request.
● res.send(body): Sends the HTTP response.
○ If the body is an object or an array, it is automatically converted to a JSON string with an
appropriate content type.

● res.status(code): This sets the response status code.


○ If not set, it is defaulted to 200 OK.
○ One common way of sending an error is by combining the status() and send() methods in a single
call like res.status(403).send("Access Denied").
Routing – Response Objects
● res.json(object): Sends a JSON response
○ This method sends a response (with the correct content-type) that is the parameter converted to a
JSON string using JSON.stringify().
○ The parameter can be any JSON type, including object, array, string, Boolean, number, or null.

● res.sendFile(path):
○ This responds with the contents of the file at path.
○ The content type of the response is guessed using the extension of the file.
Routing – Response Objects
● for a complete list, please refer to the Request documentation of Express at
● Request Objects: http://expressjs.com/en/api.html#req
● Response Objects: http://expressjs.com/en/api.html#res
ExpressJS Middleware
● An Express application is a series of middleware function calls.
● Router is nothing but a middleware function.
● Middleware functions have access to the request and response object (req,res), and the next
middleware function in the application’s request response cycle.
● The next middleware function is commonly denoted by a variable named next.
● next is the only built-in middleware (other than the router) available as part of Express.
ExpressJS Middleware
● Middleware can be at
○ The application level (i.e.,, applies to all requests) or
○ The router level (applies to specific request path patterns).
● The Middleware at the application level can be used like this: app.use(middleware function);
● The static middleware that knows the location of static files to serve.
● In order to use the same middleware in a route-specific way, you define it as:
○ app.use('/public', express.static('static'));
● This would have mounted the static files on the path /public and all static files would have to be
accessed with the prefix /public,
● For e.g.,: /public/index.html.
Summary
● Express is a web application framework for Node. It is a server-side or back-end framework, fast,
unopinionated, and minimalist web framework for Node.js.
● Use the npm init command to create a package.json file for your application.
● The command npm i express is used to install express.
● MERN has four open-source components MongoDB, Express, React, and Node.js. These components
give an end to end frameworks for developers to work with.
● Using the MERN stack enables developers to build highly efficient web applications.
● Routing refers to the mechanism for serving the client the content it has asked for.
● There are various request and response objects used for interacting with the server.
● An Express application is a series of middleware function calls. Router is nothing but a middleware
function.

You might also like