KEMBAR78
Full Stack Unit 1 | PDF | Client–Server Model | World Wide Web
0% found this document useful (0 votes)
22 views100 pages

Full Stack Unit 1

The document provides an overview of full stack web development, focusing on the client-server architecture, web applications, and the roles of servers and clients. It explains the differences between physical and virtual servers, types of servers, and the importance of communication protocols in data exchange. Additionally, it categorizes clients based on their resource reliance and outlines the client-server interaction process.

Uploaded by

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

Full Stack Unit 1

The document provides an overview of full stack web development, focusing on the client-server architecture, web applications, and the roles of servers and clients. It explains the differences between physical and virtual servers, types of servers, and the importance of communication protocols in data exchange. Additionally, it categorizes clients based on their resource reliance and outlines the client-server interaction process.

Uploaded by

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

MC4201 - Full Stack Web Development

UNIT I INTRODUCTION TO CSS and JAVASCRIPT


Introduction to Web: Server - Client - Communication Protocol (HTTP) – Structure of HTML
Documents – Basic Markup tags – Working with Text and Images with CSS– CSS Selectors –
CSS Flexbox - JavaScript: Data Types and Variables - Functions - Events – AJAX: GET and
POST

Introduction to Web

Web consists of billions of clients and server connected through wires and wireless
networks. The web clients make requests to web server. The web server receives the
request, finds the resources and return the response to the client. When a server
answers a request, it usually sends some type of content to the client. The client uses
web browser to send request to the server. The server often sends response to the
browser with a set of instructions written in HTML(HyperText Markup Language).
All browsers know how to display HTML page to the client.

Web Application

A website is a collection of static files(webpages) such as HTML pages, images,


graphics etc. A Web application is a web site with dynamic functionality on the
server. Google, Facebook, Twitter are examples of web applications.

Server

A server is a computer program or device that provides a service to another computer


program and its user, also known as the client. In a data center, the physical computer
that a server program runs on is also frequently referred to as a server. That
machine might be a dedicated server or it might be used for other purposes.
In the client/server programming model, a server program awaits and fulfills requests
from client programs, which might be running in the same, or other computers. A
given application in a computer might function as a client with requests for services
from other programs and as a server of requests from other programs.

How servers work


1
The term server can refer to a physical machine, a virtual machine or to software that
is performing server services. The way that a server works varies considerably
depending on how the word server is being used.

Physical and virtual servers

A physical server is simply a computer that is used to run server software.

A virtual server is a virtual representation of a physical server. Like a physical server,


a virtual server includes its own operating system and applications. These are kept
separate from any other virtual servers that might be running on the physical server.

The process of creating virtual machines involves installing a lightweight software


component called a hypervisor onto a physical server. The hypervisor's job is to
enable the physical server to function as a virtualization host. The virtualization host
makes the physical server's hardware resources -- such as CPU time, memory, storage
and network bandwidth -- available to one or more virtual machines.

An administrative console gives administrators the ability to allocate specific


hardware resources to each virtual server. This helps dramatically drive down
hardware costs because a single physical server can run multiple virtual servers, as
opposed to each workload needing its own physical server.

Server software

At a minimum, a server requires two software components: an operating system and


an application. The operating system acts as a platform for running the server
application. It provides access to the underlying hardware resources and provides the
dependency services that the application depends on.

The operating system also provides the means for clients to communicate with the
server application. The server's IP address and fully qualified domain name, for
example, are assigned at the operating system level.

Desktop computers vs. servers

There are both similarities and differences between desktop computers and servers.
Most servers are based on X86/X64 CPUs and can run the same code as an X86/X64
desktop computer. Unlike most desktop computers, however, physical servers often
include multiple CPU sockets and error correcting memory. Servers also generally
support a far greater quantity of memory than most desktop computers.
Because server hardware typically runs mission-critical workloads, server hardware
manufacturers design servers to support redundant components. A server might be
equipped with redundant power supplies and redundant network interfaces. These
redundant components allow a server to continue to function even if a key component
fails.

Server hardware also differs from desktop hardware in terms of its form factor.
Modern desktop computers often exist as mini towers, designed to be placed under a
desk. Although there are still some vendors that offer tower servers, most servers are
designed to be rack mounted. These rack mount systems are described as having a 1U,
2
2U or 4U form factor, depending on how much rack space they occupy -- a 2U server
takes up twice as much rack space as a 1U server.

Another key difference between a desktop computer and a server is the operating
system. A desktop operating system might be able to perform some server-like
functionality but isn't designed or licensed to take the place of a server operating
system. Windows 10, for example, is a desktop operating system.

Some Windows 10 editions include Hyper-V, Microsoft's virtual machine platform.


Even though both Windows 10 and Windows Server can run Hyper-V, Windows 10's
hypervisor is intended to be primarily used for development purposes, whereas the
version of Hyper-V included with Windows Server is designed for running production
virtual servers.

Although an organization could conceivably run a virtual server on top of Windows


10 Hyper-V, there are licensing issues to consider. Additionally, Windows Server
Hyper-V includes resiliency features that aren't found in the Windows 10 version. For
example, Windows Server supports failover clustering and virtual machine
replication.

Similarly, the Windows 10 operating system can make files available to devices on a
local network. However, Windows 10 was never designed for large-scale file sharing.
Windows Server, however, can be configured to act as a fully featured file server. In
large organizations, a distributed file system can be created across an entire server
farm for the purpose of providing better performance, scalability and resiliency than
what one physical server would be able to provide by itself.

Types of servers

Servers are often categorized in terms of their purpose. A few examples of the types
of servers available are as follows:

 Web server: a computer program that serves requested HTML pages or files.
In this case, a web browser acts as the client.
 Application server: a program in a computer in a distributed network that
provides the business logic for an application program.
 Proxy server: software that acts as an intermediary between an endpoint
device, such as a computer, and another server from which a user or client is
requesting a service.
 Mail server: an application that receives incoming emails from local users --
people within the same domain -- and remote senders and forwards outgoing
emails for delivery.
 Virtual server: a program running on a shared server that is configured in
such a way that it seems to each user that they have complete control of a
server.
 Blade server: a server chassis housing multiple thin, modular electronic circuit
boards, known as server blades. Each blade is a server in its own right, often
dedicated to a single application
 File server: a computer responsible for the central storage and management
of data files so that other computers on the same network can access them.
 Policy server: a security component of a policy-based network that
provides authorization services and facilitates tracking and control of files.
3
 Database server: this server is responsible for hosting one or more databases.
Client applications perform database queries that retrieve data from or write
data to the database that is hosted on the server.
 Print server: this server provides users with access to one or more network-
attached printers -- or print devices as some server vendors call them. The
print server acts as a queue for the print jobs that users submit. Some print
servers can prioritize the jobs in the print queue based on the job type or on
who submitted the print job.

Server components

Hardware

Servers are made up of several different components and subcomponents. At the


hardware level, servers are typically made up of a rack mount chassis containing a
power supply, a system board, one or more CPUs, memory, storage, a network
interface and a power supply.

Most server hardware supports out-of-band management through a dedicated network


port. Out-of-band management enables low-level management and monitoring of the
server, independently of the operating system. Out-of-band management systems can
be used to remotely power the server on or off, to install an operating system, and to
perform health monitoring.

Operating systems

Another component is the server operating system. A server operating system, such as
Windows Server or Linux, acts as the platform that enables applications to run. The
operating system provides applications access to the hardware resources that they
need and enables network connectivity.

The application is what enables the server to do its job. For example, a database
server would run a database application. Likewise, an email server would need to run
a mail application.
Choosing the right server

There are many factors to consider in the midst of a server selection, including virtual
machine and container consolidation. When choosing a server, evaluate the
importance of certain features based on the use cases.

Security capabilities are also important and there are a number of protection, detection
and recovery features to consider, including native data encryption to protect data in
flight and data at rest, as well as persistent event logging to provide an indelible
record of all activity.

If the server will rely on internal storage, the choice of disk types and capacity is also
important because it can have a significant influence on input/output (I/O) and
resilience.

Many organizations are shrinking the number of physical servers in their data centers
as virtualization enables fewer servers to host more workloads. The advent of cloud
computing has also changed the number of servers an organization needs to host on
4
premises.

Packing more capability into fewer boxes can reduce overall capital expenses, data
center floor space and power and cooling demands. Hosting more workloads on fewer
boxes, however, can also pose an increased risk to the business because more
workloads will be affected if the server fails or needs to be offline for routine
maintenance.

A server maintenance checklist should cover physical elements, as well as the


system's critical configuration.

Client

A client may refer to any of the following:

1. A client is a computer that connects to and uses the resources of a remote computer,
or server. Many corporate networks comprise a client computer for each employee,
5
each of which connects to the corporate server. The server provides resources like
files, information, Internet and intranet access, and external processing power. In the
case of processing, any work done on the server is referred to as "server-side" work.
Any work done on the local client is similarly called "client-side."

The following example compares a client-side script and a server-side script, and
explains how a client computer interacts with an Internet server.

Types of clients

Some software may list a type of client to help identify the type of operating system
the client uses. Below are examples of client types you may see listed.

 Apple client - Computer using macOS.


 IoT - Internet of Things device.
 Linux client - Computer running Linux.
 Smartphone or mobile - Mobile device like a smartphone.
 Windows client - Computer running Windows.

2. Client is also another name for a software program used to connect to a server.

3. A client can also be another term used to describe a user.

Used in home and corporate networks, a client is any computer hardware or software
device that requests access to a service provided by a server. Clients are typically seen
as the requesting program or user in a client-server architecture. Client end-user
devices typically include desktop computers, laptops and smartphones.

In a computer network, a client in a client-server model is what requests a service or


resource from a server. The server can be located on or off premises.

6
How does a client interact with a server?

In a client-server architecture, clients interact with servers by making requests for data
or resources that the client is not capable of providing. Clients and servers can be
located in different areas and connect via a network. They can also be located on the
same machine and connect by interprocess communications.

A distributed application framework divides tasks between servers and clients. Tasks
that can be completed by the client are typically referred to as client-side, while tasks
completed by a server are referred to as server-side.

Servers typically provide resources such as files, data, internet access, external storage
or processing power. The server puts one or more programs in charge of distributing
those services to requesting clients.

Clients and servers communicate in a request-response messaging pattern defined by


a communication protocol, such as Transmission Control Protocol/Internet Protocol
(TCP/IP). The protocol defines the language and dialog patterns used. TCP, for
example, maintains a connection between client and server until the end of a message
exchange. TCP also determines how to distribute application data, transfers and
receives packets, and manages any dropped packets. If a server receives a large
number of requests at once, the requests are organized in a scheduling system based
on priority. With client access control tools, a user can manage access to servers.

Client-side vs. server-side

The client-side is an action or operation that occurs on the user's side, while server-
side refers to actions or operations that occur on a server.

For example, JavaScript scripts are client-side, as they are executed by a browser,
which is the client. Common Gateway Interface scripts are server-side, as they run on
a server.

A server, for example, could be an Application Server, a separate computer, a


database server or a web server. When a program or device does not have the
resources to complete an operation, it will act as a client, making a request to a server,
and that operation will happen server-side.

Types of clients
7
The following examines the four ways to define the different types of clients:

 Thick client. Thick clients provide a majority of resources and data processing.
These clients rely only lightly on a server; instead, they perform most
operations client-side.
 Thin client. These lightweight clients rely heavily on a server for resources
and to perform most of the data processing.
 Hybrid client. Hybrid clients are a combination of both thin and thick clients.
This type of client processes data locally but relies on a server to store
persistent data.
 Zero client. Zero clients are slimmer and more cost-effective than thin clients.
These client devices require no configuration and have nothing stored on them.
They also use less power than thick or thin clients.

Client-server examples

Examples of client-server relationships include web, file and mail servers. A web
browser is essentially a client that requests pages from servers all over the web. The
browser is the client that sends requests while a server in another location returns the
Hypertext Markup Language (HTML) file. The computer that handles the request and
sends back the HTML file is a server.

File servers are computers that are responsible for the storage and management of
data files, enabling users to share information over a network without having to
physically transfer the files. Examples of a file server include a network attached
storage device or a separate computer that can host shared files.

File Transfer Protocol is a client-server network protocol that is used to transmit files
between computers over TCP/IP connections. The client-server protocol relies on two
communications channels between the client and server -- a command channel for
controlling the conversation and a data channel for transmitting file content.

Communication Protocol (HTTP)


8
In the digital world, communication protocols create many rules. For instance, on the
Internet, the formation of these protocols can be done by groups such as the
association of WWW (World Wide Web) or W3C & the IETF (Internet Engineering
Task) assists in providing worldwide operations & limits different types of liability as
well as vulnerabilities within these technologies. Communication protocol plays a key
role when HTTP turns into HTTPS otherwise an extensive use of SSL (Secure
Sockets Layer) certificate becomes the standard. Other types of protocols use the data
packets within global network routes and sometimes its looks like particle physics. So,
technology is advancing day by day, so different communication protocols are used in
advanced networks. The Internet of Things (IoT) assures the latest developing
communications protocols to connect the wide set of devices to a universal network.

What are Communication Protocols?

The proper descriptions of digital message formats as well as rules are known
communication protocols. The main function of these protocols is to exchange
messages from one computer system to another. These are significant in
telecommunications systems as they consistently send and receive messages. These
protocols cover error detection & correction, signaling, and authentication. They can
also explain the semantics, syntax & brings analog & digital communications
together.

Communication Protocols

The implementation of these protocols can be done within hardware as well as


software. So communications protocols are available around thousand types which are
used all over in analog & digital communications, so computer networks cannot be
present without them.

Introduction

 Protocol: A set of rules and regulations is called a protocol.


 Communication: Exchange of information from one system to another
system with a medium is called communication.
 Communication Protocol: A set of rules and regulations that allow two
electronic devices to connect to exchange the data with one and another.

Why is Communication Protocol Important?

Communication protocols assist varied network devices to converse with each other
by transmitting the analog signals, digital signals, different files & process the data
from one device to other devices. These types of protocols are applicable in
9
telecommunication & computer networks where suitable rules are executed to
transmit information from source to destination. The most vital protocols within
networking are TCP (Transmission Control Protocol) & User datagram protocol
(UDP).

10
Types of Communication Protocols

There are two types of communication protocols which are classified below:

 Inter System Protocol


 Intra System Protocol

Inter System Protocol

The inter-system protocol using to communicate the two different devices. Like
communication between computer to microcontroller kit. The communication is done
through an inter bus system.

Inter Bus System Protocols

The different categories of intersystem protocol mainly include the following.

 UART Protocol
 USART Protocol
 USB Protocol

UART Protocol

UART stands for a universal asynchronous transmitter and receiver. UART Protocols
is a serial communication with two wired protocols. Ex: Emails, SMS, Walkie-talkie.

USART Protocol

USART stands for a universal synchronous and asynchronous transmitter and receiver.
It is a serial communication of a two-wire protocol. Ex:-Telecommunications.

USB Protocol

USB stands for universal serial bus. Again it is a serial communication of two-wire
protocol. Ex: Mouse, Keyboard, Hubs, switches, pen drive.

Intra System Protocol

The Intra system protocol is used to communicate the two devices within the circuit
board. While using these intra system protocols, without going to intrasystem
protocols we will expand the peripherals of the microcontroller. The circuit
complexity and power consumption will be increased by using the intrasystem

11
protocol. Using intra system protocols circuit complexity and power consumption, the
cost is decreased and it is very secure to accessing the data.

Intra System Protocols

The different categories of intrasystem protocol mainly include the following.

 I2C Protocol
 SPI Protocol
 CAN Protocol

I2C Protocol

I2C stands for the inter-integrated circuit and it requires only two wires connecting all
peripherals to the microcontroller. I2C requires two wires SDA (serial data line) and
SCL (serial clock line) to carry information between devices. It is a master to a slave
communication protocol. Each slave has a unique address. The master device sends
the address of the target slave device and reads/writes the flag. The address matches
any slave device that the device is ON, the remaining slave devices are disabled
mode.

SPI Protocol

SPI stands for the serial peripheral interface. It is one of the serial communication
protocol developed by Motorola. Sometimes SPI protocol is also called a 4-wire
protocol. It requires four wires MOSI, MISO, SS, and SCLK.SPI protocol used to
communicate the master and slave devices.

CAN Protocol

CAN stands for the controller area network. It is a serial communication protocol. It
requires two wires CAN High (H+) and CAN low (H-). It was developed by the
Robert bosh company in 1985 for in-vehicle networks. It is based on a message-
oriented transmission protocol.

The Hypertext Transfer Protocol (HTTP) is an application-level protocol for


distributed, collaborative, hypermedia information systems. This is the foundation for
data communication for the World Wide Web (i.e. internet) since 1990. HTTP is a
generic and stateless protocol which can be used for other purposes as well using
extensions of its request methods, error codes, and headers.

Basically, HTTP is a TCP/IP based communication protocol, that is used to deliver


data (HTML files, image files, query results, etc.) on the World Wide Web. The
default port is TCP 80, but other ports can be used as well. It provides a standardized

12
way for computers to communicate with each other. HTTP specification specifies
how clients' request data will be constructed and sent to the server, and how the
servers respond to these requests.

Basic Features

There are three basic features that make HTTP a simple but powerful protocol:

HTTP is connectionless: The HTTP client, i.e., a browser initiates an HTTP


request and after a request is made, the client waits for the response. The
server processes the request and sends a response back after which client
disconnect the connection. So client and server knows about each other during
current request and response only. Further requests are made on new
connection like client and server are new to each other.

HTTP is media independent: It means, any type of data can be sent by


HTTP as long as both the client and the server know how to handle the data
content. It is required for the client as well as the server to specify the content
type using appropriate MIME-type.

HTTP is stateless: As mentioned above, HTTP is connectionless and it is a


direct result of HTTP being a stateless protocol. The server and client are
aware of each other only during a current request. Afterwards, both of them
forget about each other. Due to this nature of the protocol, neither the client
nor the browser can retain information between different requests across the
web pages.

HTTP/1.0 uses a new connection for each request/response exchange,


where as HTTP/1.1 connection may be used for one or more
request/response exchanges.

Basic Architecture

The following diagram shows a very basic architecture of a web application and
depicts where HTTP sits:

13
The HTTP protocol is a request/response protocol based on the client/server based
architecture where web browsers, robots and search engines, etc. act like HTTP
clients, and the Web server acts as a server.

Client

The HTTP client sends a request to the server in the form of a request method, URI,
and protocol version, followed by a MIME-like message containing request modifiers,
client information, and possible body content over a TCP/IP connection.

Server

The HTTP server responds with a status line, including the message's protocol version
and a success or error code, followed by a MIME-like message containing server
information, entity meta information, and possible entity-body content.

HTTP - Messages

HTTP is based on the client-server architecture model and a stateless request/response


protocol that operates by exchanging messages across a reliable TCP/IP connection.

An HTTP "client" is a program (Web browser or any other client) that establishes a
connection to a server for the purpose of sending one or more HTTP request messages.
An HTTP "server" is a program ( generally a web server like Apache Web Server or
Internet Information Services IIS, etc. ) that accepts connections in order to serve
HTTP requests by sending HTTP response messages.

HTTP makes use of the Uniform Resource Identifier (URI) to identify a given
resource and to establish a connection. Once the connection is established, HTTP
messages are passed in a format similar to that used by the Internet mail [RFC5322]
and the Multipurpose Internet Mail Extensions (MIME) [RFC2045]. These messages
include requests from client to server and responses from server to client which will
have the following format:

HTTP-message = <Request> | <Response> ; HTTP/1.1 messages

HTTP requests and HTTP responses use a generic message format of RFC 822 for
transferring the required data. This generic message format consists of the following
four items.

 A Start-line
 Zero or more header fields followed by CRLF
 An empty line (i.e., a line with nothing preceding the CRLF)
 indicating the end of the header fields
 Optionally a message-body

In the following sections, we will explain each of the entities used in an HTTP
message.
Message Start-Line

A start-line will have the following generic syntax:

14
start-line = Request-Line | Status-Line

We will discuss Request-Line and Status-Line while discussing HTTP Request and
HTTP Response messages respectively. For now, let's see the examples of start line in
case of request and response:

GET /hello.htm HTTP/1.1 (This is Request-Line sent by the client)

HTTP/1.1 200 OK (This is Status-Line sent by the server)

Header Fields

HTTP header fields provide required information about the request or response, or
about the object sent in the message body. There are four types of HTTP message
headers:

General-header: These header fields have general applicability for both


request and response messages.

Request-header: These header fields have applicability only for request


messages.

Response-header: These header fields have applicability only for response


messages.

Entity-header: These header fields define meta information about the entity-
body or, if no body is present, about the resource identified by the request.

All the above mentioned headers follow the same generic format and each of the
header field consists of a name followed by a colon (:) and the field value as follows:

message-header = field-name ":" [ field-value ]

Following are the examples of various header fields:

User-Agent: curl/7.16.3 libcurl/7.16.3 OpenSSL/0.9.7l zlib/1.2.3


Host: www.example.com
Accept-Language: en, mi
Date: Mon, 27 Jul 2009 12:28:53 GMT
Server: Apache
Last-Modified: Wed, 22 Jul 2009 19:15:56 GMT
ETag: "34aa387-d-1568eb00"
Accept-Ranges: bytes
Content-Length: 51
Vary: Accept-
Encoding
Content-Type: text/plain

Message Body
The message body part is optional for an HTTP message but if it is available, then it is
used to carry the entity-body associated with the request or response. If entity body is
associated, then usually Content-Type and Content-Length headers lines specify the
15
nature of the body associated.

A message body is the one which carries the actual HTTP request data (including
form data and uploaded, etc.) and HTTP response data from the server ( including
files, images, etc.). Shown below is the simple content of a message body:

<html>
<body>

<h1>Hello, World!</h1>

</body></html>

HTTP - Request

An HTTP client sends an HTTP request to a server in the form of a request message
which includes following format:

 A Request-line
 Zero or more header (General|Request|Entity) fields followed by CRLF
 An empty line (i.e., a line with nothing preceding the CRLF)
 indicating the end of the header fields
 Optionally a message-body

The following sections explain each of the entities used in an HTTP request message.

Request-Line

The Request-Line begins with a method token, followed by the Request-URI and the
protocol version, and ending with CRLF. The elements are separated by space SP
characters.

Request-Line = Method SP Request-URI SP HTTP-Version CRLF

Let's discuss each of the parts mentioned in the Request-Line.

Request Method

The request method indicates the method to be performed on the resource identified
by the given Request-URI. The method is case-sensitive and should always be
mentioned in uppercase. The following table lists all the supported methods in
HTTP/1.1.
S.N. Method and Description
GET

1 The GET method is used to retrieve information from the given server using a
given URI. Requests using GET should only retrieve data and should have no
other effect on the data.
HEAD
2
Same as GET, but it transfers the status line and the header section only.
16
POST
3
A POST request is used to send data to the server, for example, customer
information, file upload, etc. using HTML forms.
PUT
4
Replaces all the current representations of the target resource with the uploaded
content.
DELETE
5
Removes all the current representations of the target resource given by URI.
CONNECT
6
Establishes a tunnel to the server identified by a given URI.
OPTIONS
7
Describe the communication options for the target resource.
TRACE
8
Performs a message loop back test along with the path to the target resource.

Request-URI

The Request-URI is a Uniform Resource Identifier and identifies the resource upon
which to apply the request. Following are the most commonly used forms to specify
an URI:

Request-URI = "*" | absoluteURI | abs_path | authority

S.N. Method and Description


The asterisk * is used when an HTTP request does not apply to a particular
resource, but to the server itself, and is only allowed when the method used does
1 not necessarily apply to a resource. For example:

OPTIONS * HTTP/1.1
The absoluteURI is used when an HTTP request is being made to a proxy. The
2 proxy is requested to forward the request or service from a valid cache, and
return the response. For example:
GET http://www.w3.org/pub/WWW/TheProject.html HTTP/1.1
The most common form of Request-URI is that used to identify a
resource on an origin server or gateway. For example, a client wishing to retrieve
a resource directly from the origin server would create a TCP connection to port
80 of the host "www.w3.org" and send the following lines:

3 GET /pub/WWW/TheProject.html HTTP/1.1

Host: www.w3.org

Note that the absolute path cannot be empty; if none is present in the original
17
URI, it MUST be given as "/" (the server root).

Request Header Fields

We will study General-header and Entity-header in a separate chapter when we will


learn HTTP header fields. For now, let's check what Request header fields are.

The request-header fields allow the client to pass additional information about the
request, and about the client itself, to the server. These fields act as request
modifiers.Here is a list of some important Request-header fields that can be used
based on the requirement:

Accept-Charset

Accept-Encoding

Accept-Language

Authorization

Expect

From

Host

If-Match

If-Modified-Since

If-None-Match

If-Range

If-Unmodified-Since

Max-Forwards

Proxy-Authorization

Range

Referer

TE

User-Agent

You can introduce your custom fields in case you are going to write your own custom
Client and Web Server.

Examples of Request Message


18
Now let's put it all together to form an HTTP request to fetch hello.htm page from the
web server running on tutorialspoint.com

GET /hello.htm HTTP/1.1


User-Agent: Mozilla/4.0 (compatible; MSIE5.01; Windows NT)
Host: www.tutorialspoint.com
Accept-Language: en-us
Accept-Encoding: gzip, deflate
Connection: Keep-Alive

Here we are not sending any request data to the server because we are fetching a plain
HTML page from the server. Connection is a general-header, and the rest of the
headers are request headers. The following example shows how to send form data to
the server using request message body:

POST /cgi-bin/process.cgi HTTP/1.1


User-Agent: Mozilla/4.0 (compatible; MSIE5.01; Windows NT)
Host: www.tutorialspoint.com
Content-Type: application/x-www-form-urlencoded
Content-Length: length
Accept-Language: en-us
Accept-Encoding: gzip, deflate
Connection: Keep-Alive

licenseID=string&content=string&/paramsXML=string

Here the given URL /cgi-bin/process.cgi will be used to process the passed data and
accordingly, a response will be returned. Here content-type tells the server that the
passed data is a simple web form data and length will be the actual length of the data
put in the message body. The following example shows how you can pass plain XML
to your web server:

POST /cgi-bin/process.cgi HTTP/1.1


User-Agent: Mozilla/4.0 (compatible; MSIE5.01; Windows NT)
Host: www.tutorialspoint.com
Content-Type: text/xml; charset=utf-
8 Content-Length: length
Accept-Language: en-us
Accept-Encoding: gzip, deflate
Connection: Keep-Alive

<?xml version="1.0" encoding="utf-8"?>


<string xmlns="http://clearforest.com/">string</string>

HTTP - Response

After receiving and interpreting a request message, a server responds with an HTTP
response message:

 A Status-line
 Zero or more header (General|Response|Entity) fields followed by CRLF
19
 An empty line (i.e., a line with nothing preceding the CRLF)
 indicating the end of the header fields
 Optionally a message-body

The following sections explain each of the entities used in an HTTP response
message.

Message Status-Line

A Status-Line consists of the protocol version followed by a numeric status code and
its associated textual phrase. The elements are separated by space SP characters.

Status-Line = HTTP-Version SP Status-Code SP Reason-Phrase CRLF

HTTP Version

A server supporting HTTP version 1.1 will return the following version information:

HTTP-Version = HTTP/1.1

Status Code

The Status-Code element is a 3-digit integer where first digit of the Status-Code
defines the class of response and the last two digits do not have any categorization
role. There are 5 values for the first digit:

S.N. Code and Description


1xx: Informational
1
It means the request was received and the process is continuing.
2xx: Success
2
It means the action was successfully received, understood, and accepted.
3xx: Redirection
3
It means further action must be taken in order to complete the request.
4xx: Client Error
4
It means the request contains incorrect syntax or cannot be fulfilled.
5xx: Server Error
5
It means the server failed to fulfill an apparently valid request.

HTTP status codes are extensible and HTTP applications are not required to
understand the meaning of all registered status codes. A list of all the status codes has
been given in a separate chapter for your reference.

Response Header Fields

We will study General-header and Entity-header in a separate chapter when we will


learn HTTP header fields. For now, let's check what Response header fields are.
20
The response-header fields allow the server to pass additional information about the
response which cannot be placed in the Status- Line. These header fields give
information about the server and about further access to the resource identified by the
Request-URI.

Accept-Ranges

Age

ETag

Location

Proxy-Authenticate

Retry-After

Server

Vary

WWW-Authenticate

You can introduce your custom fields in case you are going to write your own custom
Web Client and Server.

Examples of Response Message

Now let's put it all together to form an HTTP response for a request to fetch the
hello.htm page from the web server running on tutorialspoint.com
HTTP/1.1 200 OK
Date: Mon, 27 Jul 2009 12:28:53 GMT
Server: Apache/2.2.14 (Win32)
Last-Modified: Wed, 22 Jul 2009 19:15:56 GMT
Content-Length: 88
Content-Type: text/html
Connection: Closed
<html><body><h1>Hello, World!</h1></body></html>

The following example shows an HTTP response message displaying error condition
when the web server could not find the requested page:

HTTP/1.1 404 Not Found


Date: Sun, 18 Oct 2012 10:36:20 GMT
Server: Apache/2.2.14 (Win32)
Content-Length: 230
Connection: Closed
Content-Type: text/html; charset=iso-8859-1
<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML 2.0//EN"><html><head>
<title>404 Not Found</title></head><body>
<h1>Not Found</h1>
21
<p>The requested URL /t.html was not found on this server.</p></body></html>

Following is an example of HTTP response message showing error condition when


the web server encountered a wrong HTTP version in the given HTTP request:

HTTP/1.1 400 Bad Request


Date: Sun, 18 Oct 2012 10:36:20 GMT
Server: Apache/2.2.14 (Win32)
Content-Length: 230
Content-Type: text/html; charset=iso-8859-1
Connection: Closed
<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML 2.0//EN"><html><head>
<title>400 Bad Request</title></head><body>
<h1>Bad Request</h1>
<p>Your browser sent a request that this server could not understand.</p>
<p>The request line contained invalid characters following the protocol
string.</p></body></html>

Structure of HTML Documents

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.

A Simple HTML Document

Example

<!DOCTYPE html>
<html>
<head>
<title>Page Title</title>
</head>
<body>

<h1>My First Heading</h1>


<p>My first paragraph.</p>

</body>
</html>

Example Explained

22
 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

What is an HTML Element?

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

Web Browsers

The purpose of a web browser (Chrome, Edge, Firefox, Safari) is to read HTML
documents and display them correctly.

A browser does not display the HTML tags, but uses them to determine how to
display the document:

23
HTML Page Structure

Below is a visualization of an HTML page structure:

<html>

<head>

<title>Page title</title>

</head>

<body>

<h1>This is a heading</h1>
<p>This is a paragraph.</p>

<p>This is another paragraph.</p>

</body>

</html>

Html used predefined tags and attributes to tell the browser how to display content,
means in which format, style, font size, and images to display. Html is a case
insensitive language. Case insensitive means there is no difference in upper case and
lower case ( capital and small letters) both treated as the same, for r example ‘D’ and
‘d’ both are the same here.
24
There are generally two types of tags in HTML:

1. Paired Tags: These tags come in pairs. That is they have both opening(< >)
and closing(</ >) tags.
2. Empty Tags: These tags do not require to be closed.

Below is an example of a (<b>) tag in HTML, which tells the browser to bold the text
inside it.

Tags and attributes: Tags are individuals of html structure, we have to open and
close any tag with a forward slash like this <h1> </h1>. There are some variations
with the tag some of them are self-closing tag which isn’t required to close and some
are empty tag where we can add any attributes in it. Attributes are additional
properties of html tags that define the property of any html tags. i.e. width, height,
controls, loops, input, and autoplay. These attributes also help us to store information
in meta tags by using name, content, and type attributes. Html documents structured
mentioned below:

<!DOCTYPE html>
<!-- Defines types of documents : Html 5.O -->
<html lang="en">
<!-- DEfines lanuages of content : English -->
<head>
<!-- Information about website and creator -->
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<!-- Defines the compatibility of version with browser -->
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<!-- for make website responsive -->
<meta name="author" content="Mr.X">
<meta name="Linkedin profile" content="WWW.linkedin.com/Mr.X_123" >
<!-- To give information about auther or owner -->
<meta name="description " content="A better place to learn computer science">
<!-- to explain about website in few words -->
<title>GeeksforGeeks</title>
<!-- Name of website or content to display -->
</head>
<body>
<!-- Main content of website -->
<h1>GeeksforGeeks</h1>
25
<p>A computer science portal for geeks</p>
</body>
</html>

Every Webpage must contain this code. Below is the complete explanation of each of
the tags used in the above piece of HTML code:
<!DOCTYPE html>: This tag is used to tells the HTML version. This currently tells
that the version is HTML 5.0
<html> </html> : <html> is a root element of html. It’s a biggest and main
element in complete html language, all the tags , elements and attributes enclosed
in it or we can say wrap init , which is used to structure a web page. <html> tag is
parent tag of <head> and <body> tag , other tags enclosed within <head > and
<body>. In <html > tag we use “lang” attributes to define languages of html page
such as <html lang=”en”> here en represents English language. some of them are : es
= Spanish , zh-Hans = Chinese, fr= french and el= Greek etc.
<head>: Head tag contains metadata, title, page CSS etc. Data stored in the
<head> tag is not displayed to the user, it is just written for reference purposes and
as a watermark of the owner.

<link> = To add/ link css( cascading style sheet) file. <meta> = 1. to store
data about website, organisation , creator/ owner
2. for responsive website via attributes
3. to tell compatibility of html with browser <script> = to add
javascript file.

<body>: A body tag is used to enclose all the data which a web page has from texts to
links. All the content that you see rendered in the browser is contained within this
element. Following tags and elements used in the body.

1. <h1> ,<h2> ,<h3> to <h6>


2. <p>
3. <div> and <span>
4. <b>, <i> and<u>
5. <li>,<ul>and<ol>.
6. <img> , <audio> , <video> and<iframe>
7. <table> <th> , <thead>and<tr>.
8. <form>
9. <label> and <input> others……….

Basic Markup tags

What are the most used HTML tags?

 <a> for link


 <b> to make bold text
o <strong> for bold text with emphasys
 <body> main HTML part
 <br> for break
 <div> it is a division or part of an HTML document
 <h1>... for titles
26
 <i> to make an italic text
 <img> for images in document
 <ol> is an ordered list, <ul> for an unordered list

o <li> is a list item in bulleted (ordered list)

 <p> for paragraph


 <span> to style part of text

<A> </A>

In short, this is a tag that helps you make a link to a web page, to your page, social
media site, product within online store,... The main attribute for this HTML tag is the
href (Hypertext Reference) attribute, where you put a link to a website you want to
link to. The other attribute is target, it can be used to open a link in a new window, so
that users don’t lose focus on the current page.

Example 1:
This is how you would link to our page: <a href=”
https://www.codebrainer.com”>CodeBrainer</a>

Example 2: (link will open in new window)


This is how you would link to our page and open it in a new window: <a
href=”https://www.codebrainer.com” target=”_blank”>CodeBrainer</a>

<B> </B>

If you have a lot of text, then you need to emphasise some words to let the reader
know what is important. And you do that with bold parts of the text.

Example:
CodeBrainer has a lot of <b>good</b> courses.

<BODY> </BODY>

The body part of an HTML document. In fact, this is an integral part of all HTML
documents but it is just a tag that marks what is the visible content of the page, where
the most content is.

27
<BR>

With this basic HTML tag we let the browser know, where we want some blank lines
or breaks in the text. As a matter of fact, using a few breaks makes our text breath,
this means that it is easier to read and understand.

Example (use this text in html, and it will look different):


CodeBrainer will teach you how to write HTML.<br><br>If you will have trouble
with remembering HTML tags, you should read our top 10 tags.<br>And use some of
the examples there.<br><br><br>Your CodeBrainer

<DIV> </DIV>

An element which is mostly used to group elements and to act as a template for new
controls. The div HTML tag is an element you will use to divide a significant part of
an HTML document from other parts. For examplle, let’s say you have a list of
products on your web page, you will use a div for each product.
<HEAD> </HEAD>

The head part of an HTML document. Moreover, this is where you have metadata,
which is data about the styling of the document, what kind of JavaScript libraries the
document uses, title and CSS files.

<H1> </H1> <H2> </H2> ... <H6> </H6>

Headings (levels 1-6, i.e. H3 is a subheading within a H2 subheading). H1, H2,... tags
are used to create titles. Why do we need titles, when we can style a text to look like
H tags? For instance, titles are used so that search engines and other scrapers (bots)
understand the important parts of our documents.

Example:
<h1>Top 10 HTML tags</h1> <br><br><br>In this article we will explain our list of
top 10 HTML tags.<br><br> <h2>First tag is &lt;b&gt;&lt;/b&gt;</h2>Bold is all
about making words more important.

28
<I> </I>

If you have a lot of text, then you need to emphasise some words to let the reader
know what is important. Rather, with italics you can present text that is a little tilted to
the right.

Example:
<i>CodeBrainer</i> has a lot of good courses.

29
<IMG>

We use the IMG tag to show images. Considering that images can be within files for
your web page or anywhere online. In addition, the most important attribute is src
(source), which tells where the picture is.

Example (this will show an apple and a text):


This is an apple <img
src=”https://upload.wikimedia.org/wikipedia/commons/thumb/1/15/Red_Apple.jpg/1
200px-Red_Apple.jpg” width=”100”>

<LI> </LI>

List item. A tag that is used within an ordered (<OL>) or unordered (<UL>) list. Not
to mention, you can have as many as you like.

Example:
<ul> <li>This is single list item.</li> </ul>

<OL> </OL>

Ordered list. Also includes <LI> List Items, which will be numbered automatically.
As a consequence, this is very useful if you add more list items, because the numbers
will always be in the right order.

Example:
<ol> <li>First item</li> <li>Second item</li> <li>Third item</li> </ol>

30
<P> </P>

The paragraph tag groups text into a paragraph :D (That is funny). Hence its purpose
is to separate a part of text or paragraph, this way you make it more readable and
organized..

Example:
<p>This is article about top 10 HTML tags, this will be you cheatsheet in the future,
somewhere, where you can take a look and just use it.</p><p>First tag that we will
talk about is bold. It emphasises words or sentences..</p>

<SPAN> </SPAN>

The span tag groups text for which we want to have different styling. A good
example would be if we wanted to have a red word inside a sentence.

Example:
This is a <span style=”color: red;”>warning:</span> you should have this cheat sheet
with you all the time :D

<STRONG> </STRONG>

Text is emphasised strongly - usually appears in bold, most of the time it looks like
bold too. But it has an additional meaning, that this text should be emphasised.

Example:
CodeBrainer has a lot of <strong>good</strong> courses.

<UL> </UL>

An unordered list just means that it will have bullets for each item in the list. List
items will have bullets for each item.

Example:
Animals:<br>
<ul>
<li>Fish</li>
<li>Bear</li>
<li>Dog</li>
</ul>

31
Working with Text and Images with CSS

CSS is the language we use to style a Web page.

What is CSS?

 CSS stands for Cascading Style Sheets


 CSS describes how HTML elements are to be displayed on screen, paper, or in
other media
 CSS saves a lot of work. It can control the layout of multiple web pages all at
once
 External stylesheets are stored in CSS files

CSS Text

CSS has a lot of properties for formatting text.

Text Color

The color property is used to set the color of the text. The color is specified by:

 a color name - like "red"


 a HEX value - like "#ff0000"
 an RGB value - like "rgb(255,0,0)"

The default text color for a page is defined in the body selector.

Example

body {
color: blue;
}

h1 {
color: green;
}

Text Color and Background Color

In this example, we define both the background-color property and the color property:

Example

body {
background-color: lightgrey;
color: blue;
}
32
h1 {
background-color: black;
color: white;
}

d
iv
{
background-color: blue;
color: white;
}

The CSS Text Color Property

Property Description
color Specifies the color of text

CSS Text Alignment and Text Direction

Text Alignment

The text-align property is used to set the horizontal alignment of a text.

A text can be left or right aligned, centered, or justified.

The following example shows center aligned, and left and right aligned text (left
alignment is default if text direction is left-to-right, and right alignment is default if
text direction is right-to-left):

Example

h1 {
text-align: center;
}

h2 {
text-align: left;
}
h3 {
text-align: right;
}

When the text-align property is set to "justify", each line is stretched so that every line
has equal width, and the left and right margins are straight (like in magazines and
newspapers):

Example

div {
text-align: justify;
}
33
Text Align Last

The text-align-last property specifies how to align the last line of a text.

Example

Align the last line of text in three <p> elements:

p.a {
text-align-last: right;
}

p.b {

text-align-last: center;
}

p.c {
text-align-last: justify;
}

Text Direction

The direction and unicode-bidi properties can be used to change the text direction of
an element:

Example

p{
direction: rtl;
unicode-bidi: bidi-override;
}

Vertical Alignment

The vertical-align property sets the vertical alignment of an element.


Example

Set the vertical alignment of an image in a text:

img.a {
vertical-align: baseline;
}

img.b {
vertical-align: text-top;
}

img.c {
vertical-align: text-bottom;
}
34
img.d {
vertical-align: sub;
}

img.e {
vertical-align: super;
}

The CSS Text Alignment/Direction Properties

Property Description
direction Specifies the text direction/writing direction
text-align Specifies the horizontal alignment of text

text-align-last Specifies how to align the last line of a text


Used together with the direction property to set or return whether the
unicode-bidi text should be overridden to support multiple languages in the same document
Sets the vertical alignment of an element
vertical
-align

35
CSS Text Decoration

Add a Decoration Line to Text

The text-decoration-line property is used to add a decoration line to text.

Example

h1 {
text-decoration-line: overline;
}
h2 {
text-decoration-line: line-through;
}

h3 {
text-decoration-line: underline;
}

p{
text-decoration-line: overline underline;
}

Specify a Color for the Decoration Line

The text-decoration-color property is used to set the color of the decoration line.

Example

h1 {
text-decoration-line: overline;
text-decoration-color: red;
}

h2 {
text-decoration-line: line-through;
text-decoration-color: blue;
}

h3 {
text-decoration-line: underline;
text-decoration-color: green;
}

p{
text-decoration-line: overline underline;
text-decoration-color: purple;
}
Specify a Style for the Decoration Line

36
The text-decoration-style property is used to set the style of the decoration line.

Example

h1 {
text-decoration-line: underline;
text-decoration-style: solid;
}
h2 {
text-decoration-line: underline;
text-decoration-style: double;
}

h3 {
text-decoration-line: underline;
text-decoration-style: dotted;
}

p.ex1 {
text-decoration-line: underline;
text-decoration-style: dashed;
}

p.ex2 {
text-decoration-line: underline;
text-decoration-style: wavy;
}

p.ex3 {
text-decoration-line: underline;
text-decoration-color: red;
text-decoration-style: wavy;
}

Specify the Thickness for the Decoration Line

The text-decoration-thickness property is used to set the thickness of the decoration


line.

Example

h1 {
text-decoration-line: underline;
text-decoration-thickness: auto;
}

h2 {
text-decoration-line: underline;
text-decoration-thickness: 5px;
}

h3 {
37
text-decoration-line: underline;
text-decoration-thickness: 25%;
}

p{
text-decoration-line: underline;
text-decoration-color: red;
text-decoration-style: double;
text-decoration-thickness: 5px;
}

The Shorthand Property

The text-decoration property is a shorthand property for:

 text-decoration-line (required)
 text-decoration-color (optional)
 text-decoration-style (optional)
 text-decoration-thickness (optional)

Example

h1 {
text-decoration: underline;
}

h2 {
text-decoration: underline red;
}

h3 {
text-decoration: underline red double;
}

p{
text-decoration: underline red double 5px;
}

A Small Tip

All links in HTML are underlined by default. Sometimes you see that links are styled
with no underline. The text-decoration: none; is used to remove the underline from
links, like this:

Example

a{
text-decoration: none;
}

All CSS text-decoration Properties

38
Property Description
text-decoration Sets all the text-decoration properties in one declaration
text-decoration-color Specifies the color of the text-decoration
text-decoration-line Specifies the kind of text decorat
ion to be used (underline,
overline, etc.)
text-decoration-style Specifies the style of the text decoration (solid, dotted, etc.)
text-decoration-thickness Specifies the thickness of the text decoration line

Text Transformation

The text-transform property is used to specify uppercase and lowercase letters in a


text.

It can be used to turn everything into uppercase or lowercase letters, or capitalize the
first letter of each word:

Example

p.uppercase {
text-transform: uppercase;
}

p.lowercase {
text-transform: lowercase;
}

p.capitalize {
text-transform: capitalize;
}

The CSS Text Transformation

Property Property Description


text-transform Controls the capitalization of text

CSS Text Indentation, Letter Spacing, Line Height, Word Spacing, and White
Space

Text Indentation

The text-indent property is used to specify the indentation of the first line of a text:

Example

p{
text-indent: 50px;
}
39
Letter Spacing

The letter-spacing property is used to specify the space between the characters in a
text.

The following example demonstrates how to increase or decrease the space between
characters:

Example

h1 {
letter-spacing: 5px;
}

h2 {
letter-spacing: -2px;
}

Line Height

The line-height property is used to specify the space between lines:

Example

p.small {
line-height: 0.8;
}

p.big {

line-height: 1.8;
}

Word Spacing

The word-spacing property is used to specify the space between the words in a text.

The following example demonstrates how to increase or decrease the space between
words:

Example

p.one {
word-spacing: 10px;
}

p.two {
word-spacing: -2px;
}

40
White Space

The white-space property specifies how white-space inside an element is handled.

This example demonstrates how to disable text wrapping inside an element:

Example

p{
white-space: nowrap;
}

The CSS Text Spacing Properties

Property Description
letter-spacing Specifies the space between characters in a text
line-height Specifies the line height
text-indent Specifies the indentation of the first line in a text-block
white-space Specifies how to handle white-space inside an element
word-spacing Specifies the space between words in a text

Text Shadow

The text-shadow property adds shadow to text.

In its simplest use, you only specify the horizontal shadow (2px) and the vertical
shadow (2px):

Text shadow effect!

Example

h1 {
text-shadow: 2px 2px;
}

Next, add a color (red) to the shadow:

Text shadow effect!

Example

h1 {
text-shadow: 2px 2px red;
}

41
Then, add a blur effect (5px) to the shadow:

Text shadow effect!

Example

h1 {
text-shadow: 2px 2px 5px red;
}

More Text Shadow Examples

Example 1

Text-shadow on a white text:

h1 {
color: white;
text-shadow: 2px 2px 4px #000000;
}

Example 2

Text-shadow with red neon glow:

h1 {
text-shadow: 0 0 3px #ff0000;
}

Example 3

Text-shadow with red and blue neon glow:

h1 {
text-shadow: 0 0 3px #ff0000, 0 0 5px #0000ff;
}

Example 4

h1 {

color: white;
text-shadow: 1px 1px 2px black, 0 0 25px blue, 0 0 5px darkblue;
}

CSS Styling Images

Rounded Images

Use the border-radius property to create rounded images:

42
Example

Rounded Image:

img {
border-radius: 8px;
}

Example

Circled Image:

img {
border-radius: 50%;
}

Thumbnail Images

Use the border property to create thumbnail images.

Example

img {
border: 1px solid #ddd;
border-radius: 4px;
padding: 5px;
width: 150px;
}

img:hover {
box-shadow: 0 0 2px 1px rgba(0, 140, 186, 0.5);
}

<a href="paris.jpg">
<img src="paris.jpg" alt="Paris">
</a>

Responsive Images

Responsive images will automatically adjust to fit the size of the screen.

If you want an image to scale down if it has to, but never scale up to be larger than its
original size, add the following:

Example

img {
max-width: 100%;
height: auto;
}

43
Center an Image

To center an image, set left and right margin to auto and make it into a block element:

Example

img {
display: block;
margin-left: auto;
margin-right: auto;
width: 50%;
}

Polaroid Images / Cards

Example

div.polaroid {
width: 80%;
background-color: white;
box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
}

img {width: 100%}

div.container {
text-align: center;
padding: 10px 20px;
}

Transparent Image

The opacity property can take a value from 0.0 - 1.0. The lower value, the more
transparent:

Example

img {
opacity: 0.5;
}

Image Text

How to position text in an image:

<!DOCTYPE html>

<html>

44
<head>

<style>

.container {

position: relative;

.topleft {

position: absolute;

top: 8px;

left: 16px;

font-size: 18px;

img {

width: 100%;

height: auto;

opacity: 0.3;

</style>

</head>

<body>

<h2>Image Text</h2>

<p>Add some text to an image in the top left corner:</p>

<div class="container">

<img src="img_5terre_wide.jpg" alt="Cinque Terre" width="1000" height="300">

45
<div class="topleft">Top Left</div>

</div>

</body>

</html>

Image Filters

The CSS filter property adds visual effects (like blur and saturation) to an element.

Example

Change the color of all images to black and white (100% gray):

img {

filter: grayscale(100%);
}

Image Hover Overlay

Create an overlay effect on hover:

<!DOCTYPE html>
<html>
<head>
<style>
.container {
position: relative;
width: 50%;
}

.image {
display: block;
width: 100%;
height: auto;
}

.overlay {
position: absolute;
bottom: 100%;
left: 0;
right: 0;
background-color: #008CBA;
overflow: hidden;
width: 100%;
height: 0;
transition: .5s ease;

46
}

.container:hover .overlay {
bottom: 0;
height: 100%;
}

.text {
white-space: nowrap;
color: white;
font-size: 20px;
position: absolute;
overflow: hidden;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
-ms-transform: translate(-50%, -50%);
}
</style>
</head>
<body>

<h2>Slide in Overlay from the Top</h2>

<div class="container">
<img src="img_avatar.png" alt="Avatar" class="image">
<div class="overlay">
<div class="text">Hello World</div>
</div>
</div>

</body>
</html>

Flip an Image

Example

img:hover {
transform: scaleX(-1);
}

Responsive Image Gallery

CSS can be used to create image galleries. This example use media queries to re-
arrange the images on different screen sizes.

Example

47
.responsive {
padding: 0 6px;
float: left;
width: 24.99999%;
}

@media only screen and (max-width: 700px){


.responsive {
width: 49.99999%;
margin: 6px 0;
}
}

@media only screen and (max-width: 500px){


.responsive {
width: 100%;
}
}

Image Modal (Advanced)

This is an example to demonstrate how CSS and JavaScript can work together.

First, use CSS to create a modal window (dialog box), and hide it by default.

Example

// Get the modal


var modal = document.getElementById('myModal');

// Get the image and insert it inside the modal - use its "alt" text as a caption
var img = document.getElementById('myImg');
var modalImg = document.getElementById("img01");
var captionText = document.getElementById("caption");
img.onclick = function(){
modal.style.display = "block";
modalImg.src = this.src;
captionText.innerHTML = this.alt;
}

// Get the <span> element that closes the modal


var span = document.getElementsByClassName("close")[0];

// When the user clicks on <span> (x), close the modal


span.onclick = function() {
modal.style.display = "none";
}

48
CSS Selectors

A CSS selector selects the HTML element(s) you want to style.

CSS Selectors

CSS selectors are used to "find" (or select) the HTML elements you want to style.

We can divide CSS selectors into five categories:

 Simple selectors (select elements based on name, id, class)


 Combinator selectors (select elements based on a specific relationship between
them)
 Pseudo-class selectors (select elements based on a certain state)
 Pseudo-elements selectors (select and style a part of an element)
 Attribute selectors (select elements based on an attribute or attribute value)

The CSS element Selector

The element selector selects HTML elements based on the element name.

Example

Here, all <p> elements on the page will be center-aligned, with a red text color:

p{
text-align: center;
color: red;
}
1. <!DOCTYPE html>
2. <html>
3. <head>
4. <style>
5. p{
6. text-align: center;
7. color: blue;
8. }
9. </style>
10. </head>
11. <body>
12. <p>This style will be applied on every paragraph.</p>
13. <p id="para1">Me too!</p>
14. <p>And me!</p>
15. </body>
16. </html>

49
Output: This style will be applied on every paragraph.

Me too!

And me!

The CSS id Selector

The id selector uses the id attribute of an HTML element to select a specific element.

The id of an element is unique within a page, so the id selector is used to select one
unique element!

To select an element with a specific id, write a hash (#) character, followed by the id
of the element.

Let?s take an example with the id "para1".

Example

The CSS rule below will be applied to the HTML element with id="para1":

#para1 {
text-align: center;

}
1. <!DOCTYPE html>
2. <html>
3. <head>
4. <style>
5. #para1 {
6. text-align: center;
7. color: blue;
8. }
9. </style>
10. </head>
11. <body>
12. <p id="para1">Hello Javatpoint.com</p>
13. <p>This paragraph will not be affected.</p>
14. </body>
15. </html>

Output: Hello Javatpoint.com

50
The CSS class Selector

The class selector selects HTML elements with a specific class attribute.

To select elements with a specific class, write a period (.) character, followed by the
class name.

Example

In this example all HTML elements with class="center" will be red and center-
aligned:

.center {
text-align: center;
color: red;
}
1. <!DOCTYPE html>
2. <html>
3. <head>
4. <style>
5. .center {
6. text-align: center;
7. color: blue;
8. }
9. </style>
10. </head>
11. <body>
12. <h1 class="center">This heading is blue and center-aligned.</h1>
13. <p class="center">This paragraph is blue and center-aligned.</p>
14. </body>
15. </html>

Output:

This heading is blue and center-aligned.

This paragraph is blue and center-aligned.

You can also specify that only specific HTML elements should be affected by a class.

Example

In this example only <p> elements with class="center" will be red and
center-aligned:
51
p.center {
text-align: center;
color: red;
}

HTML elements can also refer to more than one class.

Example

In this example the <p> element will be styled according to class="center" and to
class="large":

<p class="center large">This paragraph refers to two classes.</p>

The CSS Universal Selector

The universal selector (*) selects all HTML elements on the page.

Example

The CSS rule below will affect every HTML element on the page:

*{
text-align: center;
color: blue;
}
1. <!DOCTYPE html>
2. <html>
3. <head>
4. <style>
5. * {
6. color: green;
7. font-size: 20px;
8. }
9. </style>
10.</head>
11.<body>
12.<h2>This is heading</h2>
13.<p>This style will be applied on every paragraph.</p>
14.<p id="para1">Me too!</p>
15.<p>And me!</p>
16.</body>
17.</html>

52
Output:

This is heading

This style will be applied on every paragraph.

Me too!

And me!

The CSS Grouping Selector

The grouping selector selects all the HTML elements with the same style definitions.

Look at the following CSS code (the h1, h2, and p elements have the same style
definitions):

h1 {
text-align: center;
color: red;
}

h2 {
text-align: center;
color: red;
}

p{
text-align: center;
color: red;
}

1. <!DOCTYPE html>
2. <html>
3. <head>
4. <style>
5. h1, h2, p {
6. text-align: center;
7. color: blue;
8. }
9. </style>
10. </head>
11. <body>
12. <h1>Hello Javatpoint.com</h1>
13. <h2>Hello Javatpoint.com (In smaller font)</h2>
14. <p>This is a paragraph.</p>
15. </body>
16. </html>
53
Output:

Hello Javatpoint.com

Hello Javatpoint.com (In smaller font)

This is a paragraph.

It will be better to group the selectors, to minimize the code.

To group selectors, separate each selector with a comma.

Example

In this example we have grouped the selectors from the code above:

h1, h2, p {
text-align: center;
color: red;
}

CSS Combinators

A combinator is something that explains the relationship between the selectors.

A CSS selector can contain more than one simple selector. Between the simple
selectors, we can include a combinator.

There are four different combinators in CSS:

 descendant selector (space)


 child selector (>)
 adjacent sibling selector (+)
 general sibling selector (~)
Descendant Selector

The descendant selector matches all elements that are descendants of a specified
element.

The following example selects all <p> elements inside <div> elements:

Example

div p {
background-color: yellow;
}

Child Selector (>)

The child selector selects all elements that are the children of a specified element.

54
The following example selects all <p> elements that are children of a <div> element:

Example

div > p {
background-color: yellow;
}

Adjacent Sibling Selector (+)

The adjacent sibling selector is used to select an element that is directly after another
specific element.

Sibling elements must have the same parent element, and "adjacent" means
"immediately following".

The following example selects the first <p> element that are placed immediately after
<div> elements:

Example

div + p {
background-color: yellow;
}

General Sibling Selector (~)

The general sibling selector selects all elements that are next siblings of a specified
element.

The following example selects all <p> elements that are next siblings of <div>
elements:
Example

div ~ p {
background-color: yellow;
}

CSS Pseudo-classes

What are Pseudo-classes?

A pseudo-class is used to define a special state of an element.

For example, it can be used to:

 Style an element when a user mouses over it


 Style visited and unvisited links differently
 Style an element when it gets focus

Syntax

55
The syntax of pseudo-classes:

selector:pseudo-class {
property: value;
}

Anchor Pseudo-classes

Links can be displayed in different ways:

Example

/* unvisited link */
a:link {
color: #FF0000;
}

/* visited link */
a:visited {
color: #00FF00;
}

/* mouse over link */


a:hover {
color: #FF00FF;
}

/* selected link */
a:active {
color: #0000FF;
}

Pseudo-classes and HTML Classes

Pseudo-classes can be combined with HTML classes:

When you hover over the link in the example, it will change color:

Example

a.highlight:hover {
color: #ff0000;
}

Hover on <div>

An example of using the :hover pseudo-class on a <div> element:

Example

div:hover {
background-color: blue;
56
}

Simple Tooltip Hover

Hover over a <div> element to show a <p> element (like a tooltip):

Hover over me to show the <p> element.

Example

p{
display: none;
background-color: yellow;
padding: 20px;
}

div:hover p {
display: block;
}

CSS - The :first-child Pseudo-class

The :first-child pseudo-class matches a specified element that is the first child of
another element.
Match the first <p> element

In the following example, the selector matches any <p> element that is the first child
of any element:

Example

p:first-child {
color: blue;
}

Match the first <i> element in all <p> elements

In the following example, the selector matches the first <i> element in all <p>
elements:

Example

p i:first-child {
color: blue;
}

Match all <i> elements in all first child <p> elements

In the following example, the selector matches all <i> elements in <p> elements that
are the first child of another element:

Example
57
p:first-child i {
color: blue;
}

CSS - The :lang Pseudo-class

The :lang pseudo-class allows you to define special rules for different languages.

In the example below, :lang defines the quotation marks for <q> elements with
lang="no":

Example

<html>
<head>
<style>
q:lang(no) {
quotes: "~" "~";
}
</style>
</head>
<body>

<p>Some text <q lang="no">A quote in a paragraph</q> Some text.</p>

</body>
</html>

CSS Pseudo-elements

What are Pseudo-Elements?

A CSS pseudo-element is used to style specified parts of an element.

For example, it can be used to:

 Style the first letter, or line, of an element


 Insert content before, or after, the content of an element

Syntax

The syntax of pseudo-elements:

selector::pseudo-element {
property: value;
}

The ::first-line Pseudo-element

The ::first-line pseudo-element is used to add a special style to the first line of a text.

58
The following example formats the first line of the text in all <p> elements:

Example

p::first-line {
color: #ff0000;
font-variant: small-caps;
}

Note: The ::first-line pseudo-element can only be applied to block-level elements.

The following properties apply to the ::first-line pseudo-element:

 font properties
 color properties
 background properties
 word-spacing
 letter-spacing
 text-decoration
 vertical-align
 text-transform
 line-height
 clear

Notice the double colon notation - ::first-line versus :first-line

The double colon replaced the single-colon notation for pseudo-elements in CSS3.
This was an attempt from W3C to distinguish between pseudo-classes and pseudo-
elements.

The single-colon syntax was used for both pseudo-classes and pseudo-elements in
CSS2 and CSS1.

For backward compatibility, the single-colon syntax is acceptable for CSS2 and CSS1
pseudo-elements.

The ::first-letter Pseudo-element

The ::first-letter pseudo-element is used to add a special style to the first letter of a
text.

The following example formats the first letter of the text in all <p> elements:

Example

p::first-letter {
color: #ff0000;
font-size: xx-large;
}

Note: The ::first-letter pseudo-element can only be applied to block-level elements.

59
The following properties apply to the ::first-letter pseudo- element:

 font properties
 color properties
 background properties
 margin properties
 padding properties
 border properties
 text-decoration
 vertical-align (only if "float" is "none")
 text-transform
 line-height
 float
 clear

Pseudo-elements and HTML Classes

Pseudo-elements can be combined with HTML classes:


Example

p.intro::first-letter {
color: #ff0000;
font-size: 200%;
}

The example above will display the first letter of paragraphs with class="intro", in red
and in a larger size.

Multiple Pseudo-elements

Several pseudo-elements can also be combined.

In the following example, the first letter of a paragraph will be red, in an xx-large font
size. The rest of the first line will be blue, and in small-caps. The rest of the paragraph
will be the default font size and color:

Example

p::first-letter {
color: #ff0000;
font-size: xx-large;
}

p::first-line {
color: #0000ff;
font-variant: small-caps;
}

CSS - The ::before Pseudo-element

The ::before pseudo-element can be used to insert some content before the content of
an element.
60
The following example inserts an image before the content of each <h1> element:

Example

h1::before {
content: url(smiley.gif);
}

CSS - The ::after Pseudo-element

The ::after pseudo-element can be used to insert some content after the content of an
element.

The following example inserts an image after the content of each <h1> element:
Example

h1::after {
content: url(smiley.gif);
}

CSS - The ::marker Pseudo-element

The ::marker pseudo-element selects the markers of list items.

The following example styles the markers of list items:

Example

::marker {
color: red;
font-size: 23px;
}

CSS - The ::selection Pseudo-element

The ::selection pseudo-element matches the portion of an element that is selected by a


user.

The following CSS properties can be applied to ::selection: color, background, cursor,
and outline.

The following example makes the selected text red on a yellow background:

Example

::selection {
color: red;
background: yellow;
}

CSS Attribute Selectors


61
Style HTML Elements With Specific Attributes

It is possible to style HTML elements that have specific attributes or attribute values.

CSS [attribute] Selector

The [attribute] selector is used to select elements with a specified attribute.

The following example selects all <a> elements with a target attribute:

Example

a[target] {
background-color: yellow;
}

CSS [attribute="value"] Selector

The [attribute="value"] selector is used to select elements with a specified attribute


and value.

The following example selects all <a> elements with a target="_blank" attribute:

Example

a[target="_blank"] {
background-color: yellow;
}

CSS [attribute~="value"] Selector

The [attribute~="value"] selector is used to select elements with an attribute value


containing a specified word.

The following example selects all elements with a title attribute that contains a
space-separated list of words, one of which is "flower":

Example

[title~="flower"] {
border: 5px solid yellow;
}
The example above will match elements with title="flower", title="summer flower",
and title="flower new", but not title="my-flower" or title="flowers".

CSS [attribute|="value"] Selector

The [attribute|="value"] selector is used to select elements with the specified attribute,
whose value can be exactly the specified value, or the specified value followed by a
hyphen (-).

62
Example

[class|="top"] {
background: yellow;
}
CSS [attribute^="value"] Selector

The [attribute^="value"] selector is used to select elements with the specified attribute,
whose value starts with the specified value.

The following example selects all elements with a class attribute value that starts with
"top":

Example

[class^="top"] {
background: yellow;
}

CSS [attribute$="value"] Selector

The [attribute$="value"] selector is used to select elements whose attribute value ends
with a specified value.

The following example selects all elements with a class attribute value that ends with
"test":

Example

[class$="test"] {
background: yellow;
}

CSS [attribute*="value"] Selector

The [attribute*="value"] selector is used to select elements whose attribute value


contains a specified value.

The following example selects all elements with a class attribute value that contains
"te":

Example

[class*="te"] {
background: yellow;
}

Styling Forms

The attribute selectors can be useful for styling forms without class or ID:

Example
63
input[type="text"] {
width: 150px;
display: block;
margin-bottom: 10px;
background-color: yellow;
}

input[type="button"] {
width: 120px;
margin-left: 35px;

display: block;
}

CSS Flexbox

CSS Flexbox

CSS Flexbox Layout Module

Before the Flexbox Layout module, there were four layout modes:

 Block, for sections in a webpage


 Inline, for text
 Table, for two-dimensional table data
 Positioned, for explicit position of an element

The Flexible Box Layout Module, makes it easier to design flexible responsive layout
structure without using float or positioning.

Browser Support

The flexbox properties are supported in all modern browsers.

Flexbox Elements

To start using the Flexbox model, you need to first define a flex container.

64
The element above represents a flex container (the blue area) with three flex items.

Example

A flex container with three flex items:

<div class="flex-container">
<div>1</div>
<div>2</div>
<div>3</div>
</div>

CSS Flex Container

Parent Element (Container)

This is a flex container (the blue area) with three flex items:

The flex container becomes flexible by setting the display property to flex:

Example

.flex-container {
display: flex;
}

The flex container properties are:

 flex-direction
 flex-wrap
 flex-flow
 justify-content
 align-items
 align-content

The flex-direction Property

The flex-direction property defines in which direction the container wants to stack the
flex items.

65
Example

The column value stacks the flex items vertically (from top to bottom):

.flex-container {
display: flex;
flex-direction: column;
}

Example

The column-reverse value stacks the flex items vertically (but from bottom to top):

.flex-container {
display: flex;
flex-direction: column-reverse;
}

Example

The row value stacks the flex items horizontally (from left to right):

.flex-container {
display: flex;
flex-direction: row;
}

Example

The row-reverse value stacks the flex items horizontally (but from right to left):

.flex-container {
display: flex;
flex-direction: row-reverse;
}

The flex-wrap Property

The flex-wrap property specifies whether the flex items should wrap or not.
The examples below have 12 flex items, to better demonstrate the flex-wrap property.

66
Example

The wrap value specifies that the flex items will wrap if necessary:

.flex-container {
display: flex;
flex-wrap: wrap;
}

Example

The nowrap value specifies that the flex items will not wrap (this is default):

.flex-container {
display: flex;
flex-wrap: nowrap;
}

Example

The wrap-reverse value specifies that the flexible items will wrap if necessary, in
reverse order:

.flex-container {
display: flex;
flex-wrap: wrap-reverse;
}

The flex-flow Property

The flex-flow property is a shorthand property for setting both the flex-direction and
flex-wrap properties.

Example

.flex-container {
display: flex;
flex-flow: row wrap;
}
The justify-content Property

The justify-content property is used to align the flex items:

Example

The center value aligns the flex items at the center of the container:

67
.flex-container {
display: flex;
justify-content: center;
}

Example

The flex-start value aligns the flex items at the beginning of the container (this is
default):

.flex-container {
display: flex;
justify-content: flex-start;
}

Example

The flex-end value aligns the flex items at the end of the container:

.flex-container {
display: flex;
justify-content: flex-end;
}

Example

The space-around value displays the flex items with space before, between, and after
the lines:

.flex-container {
display: flex;
justify-content: space-around;
}

Example

The space-between value displays the flex items with space between the lines:
.flex-container {
display: flex;
justify-content: space-between;
}

The align-items Property

The align-items property is used to align the flex items.

68
In these examples we use a 200 pixels high container, to better demonstrate the
align-items property.

Example

The center value aligns the flex items in the middle of the container:

.flex-container {
display: flex;
height: 200px;
align-items: center;
}

Example

The flex-start value aligns the flex items at the top of the container:

.flex-container {
display: flex;
height: 200px;
align-items: flex-start;
}

Example

The flex-end value aligns the flex items at the bottom of the container:

.flex-container {
display: flex;
height: 200px;
align-items: flex-end;
}
Example

The stretch value stretches the flex items to fill the container (this is default):

.flex-container {
display: flex;
height: 200px;
align-items: stretch;
}

Example

The baseline value aligns the flex items such as their baselines aligns:

.flex-container {
display: flex;
height: 200px;
align-items: baseline;
}

69
The align-content Property

The align-content property is used to align the flex lines.

In these examples we use a 600 pixels high container, with the flex-wrap property set
to wrap, to better demonstrate the align-content property.

Example

The space-between value displays the flex lines with equal space between them:

.flex-container {
display: flex;
height: 600px;
flex-wrap: wrap;
align-content: space-between;
}
Example

The space-around value displays the flex lines with space before, between, and after
them:

.flex-container {
display: flex;
height: 600px;
flex-wrap: wrap;
align-content: space-around;
}

Example

The stretch value stretches the flex lines to take up the remaining space (this is
default):

.flex-container {
display: flex;
height: 600px;
flex-wrap: wrap;
align-content: stretch;
70
}

Example

The center value displays display the flex lines in the middle of the container:

.flex-container {
display: flex;
height: 600px;
flex-wrap: wrap;
align-content: center;
}

Example

The flex-start value displays the flex lines at the start of the container:

.flex-container {
display: flex;
height: 600px;
flex-wrap: wrap;
align-content: flex-start;
}

Example

The flex-end value displays the flex lines at the end of the container:
.flex-container {
display: flex;
height: 600px;
flex-wrap: wrap;
align-content: flex-end;
}

Perfect Centering

In the following example we will solve a very common style problem: perfect
centering.

SOLUTION: Set both the justify-content and align-items properties to center, and the
flex item will be perfectly centered:

Example

.flex-container {
71
display: flex;
height: 300px;
justify-content: center;
align-items: center;
}

The CSS Flexbox Container Properties

The following table lists all the CSS Flexbox Container properties:

Property Description
Modifies the behavior of the flex-wrap property. It is similar to
align-content align-items, but instead of aligning flex items, it aligns flex lines
Vertically aligns the flex items when the items do not use all
align-items available space on the cross-axis
display Specifies the type of box used for an HTML element
Specifies the direction of the flexible items inside a flex
flex-direction container
flex-flow A shorthand property for flex-direction and flex-wrap
Specifies whether the flex items should wrap or not, if there is
flex-wrap not enough room for them on one flex line
Horizontally aligns the flex items when the items do not use all
justify-content available space on the main-axis
CSS Flex Items

Child Elements (Items)

The direct child elements of a flex container automatically becomes flexible (flex)
items.

The element above represents four blue flex items inside a grey flex container.

Example

<div class="flex-container">
<div>1</div>
<div>2</div>
<div>3</div>
<div>4</div>
</div>

The flex item properties are:

 order
 flex-grow
 flex-shrink
 flex-basis
 flex
72
 align-self

The order Property

The order property specifies the order of the flex items.

The first flex item in the code does not have to appear as the first item in the layout.

The order value must be a number, default value is 0.

Example

The order property can change the order of the flex items:

<div class="flex-container">
<div style="order: 3">1</div>
<div style="order: 2">2</div>
<div style="order: 4">3</div>
<div style="order: 1">4</div>
</div>

The flex-grow Property

The flex-grow property specifies how much a flex item will grow relative to the rest
of the flex items.

The value must be a number, default value is 0.

Example

Make the third flex item grow eight times faster than the other flex items:

<div class="flex-container">
<div style="flex-grow: 1">1</div>
<div style="flex-grow: 1">2</div>
<div style="flex-grow: 8">3</div>
</div>

The flex-shrink Property

The flex-shrink property specifies how much a flex item will shrink relative to the rest
of the flex items.

73
The value must be a number, default value is 1.

Example

Do not let the third flex item shrink as much as the other flex items:

<div class="flex-container">
<div>1</div>
<div>2</div>
<div style="flex-shrink: 0">3</div>
<div>4</div>
<div>5</div>
<div>6</div>
<div>7</div>
<div>8</div>
<div>9</div>
<div>10</div>
</div>

The flex-basis Property

The flex-basis property specifies the initial length of a flex item.

Example

Set the initial length of the third flex item to 200 pixels:

<div class="flex-container">
<div>1</div>
<div>2</div>
<div style="flex-basis: 200px">3</div>
<div>4</div>
</div>

The flex Property

The flex property is a shorthand property for the flex-grow, flex-shrink, and flex-basis
properties.

Example

Make the third flex item not growable (0), not shrinkable (0), and with an initial
length of 200 pixels:

<div class="flex-container">
<div>1</div>
<div>2</div>
<div style="flex: 0 0 200px">3</div>
<div>4</div>
74
</div>

The align-self Property

The align-self property specifies the alignment for the selected item inside the flexible
container.

The align-self property overrides the default alignment set by the container's align-
items property.

In these examples we use a 200 pixels high container, to better demonstrate the align-self property:

Example

Align the third flex item in the middle of the container:

<div class="flex-container">
<div>1</div>
<div>2</div>
<div style="align-self: center">3</div>
<div>4</div>
</div>

Example

Align the second flex item at the top of the container, and the third flex item at the
bottom of the container:

<div class="flex-container">
<div>1</div>
<div style="align-self: flex-start">2</div>
<div style="align-self: flex-end">3</div>
<div>4</div>
</div>

The CSS Flexbox Items Properties

The following table lists all the CSS Flexbox Items properties:

Property Description
Specifies the alignment for a flex item (overrides the flex
align-self container's align-items property)
A shorthand property for the flex-grow, flex-shrink, and the
flex flex-basis properties
flex-basis Specifies the initial length of a flex item
Specifies how much a flex item will grow relative to the rest of
flex-grow the flex items inside the same container
75
Specifies how much a flex item will shrink relative to the rest of
flex-shrink the flex items inside the same container
order Specifies the order of the flex items inside the same container

Responsive Flexbox

For example, if you want to create a two-column layout for most screen sizes, and a
one-column layout for small screen sizes (such as phones and tablets), you can change
the flex-direction from row to column at a specific breakpoint (800px in the example
below):
Example

.flex-container {
display: flex;
flex-direction: row;
}

/* Responsive layout - makes a one column layout instead of a two-column layout */


@media (max-width: 800px) {
.flex-container {
flex-direction: column;
}
}

Another way is to change the percentage of the flex property of the flex items to
create different layouts for different screen sizes. Note that we also have to include
flex-wrap: wrap; on the flex container for this example to work:

Example

.flex-container {
display: flex;
flex-wrap: wrap;
}

.flex-item-left {
flex: 50%;
}

.flex-item-right {
flex: 50%;
}

/* Responsive layout - makes a one column layout instead of a two-column layout */


@media (max-width: 800px) {
.flex-item-right, .flex-item-left {
flex: 100%;
}
}

JavaScript

76
JavaScript is the world's most popular programming language.

JavaScript is the programming language of the Web.

JavaScript is easy to learn.


Why Study JavaScript?

JavaScript is one of the 3 languages all web developers must learn:

1. HTML to define the content of web pages

2. CSS to specify the layout of web pages

3. JavaScript to program the behavior of web pages

Data types and Variables

JavaScript Data Types

JavaScript variables can hold different data types: numbers, strings, objects and more:

let length = 16; // Number


let lastName = "Johnson"; // String
let x = {firstName:"John", lastName:"Doe"}; // Object

The Concept of Data Types

In programming, data types is an important concept.

To be able to operate on variables, it is important to know something about the type.

Without data types, a computer cannot safely solve this:

let x = 16 + "Volvo";

Does it make any sense to add "Volvo" to sixteen? Will it produce an error or will it
produce a result?

JavaScript will treat the example above as:

let x = "16" + "Volvo";

When adding a number and a string, JavaScript will treat the number as a string.

Example

let x = 16 + "Volvo";

Example
77
let x = "Volvo" + 16;
JavaScript evaluates expressions from left to right. Different sequences can produce
different results:

JavaScript:

let x = 16 + 4 + "Volvo";

Result:

20Volvo

JavaScript:

let x = "Volvo" + 16 + 4;

Result:

Volvo164

In the first example, JavaScript treats 16 and 4 as numbers, until it reaches "Volvo".

In the second example, since the first operand is a string, all operands are treated as
strings.

JavaScript Types are Dynamic

JavaScript has dynamic types. This means that the same variable can be used to hold
different data types:

Example

let x; // Now x is undefined


x = 5; // Now x is a Number
x = "John"; // Now x is a String

JavaScript Strings

A string (or a text string) is a series of characters like "John Doe".

Strings are written with quotes. You can use single or double quotes:

Example

let carName1 = "Volvo XC60"; // Using double quotes


let carName2 = 'Volvo XC60'; // Using single quotes

You can use quotes inside a string, as long as they don't match the quotes surrounding
the string:

78
Example

let answer1 = "It's alright"; // Single quote inside double quotes


let answer2 = "He is called 'Johnny'"; // Single quotes inside double quotes
let answer3 = 'He is called "Johnny"'; // Doubl
e quotes inside single quotes

JavaScript Numbers

JavaScript has only one type of numbers.

Numbers can be written with, or without decimals:

Example

let x1 = 34.00; // Written with decimals


let x2 = 34; // Written without decimals

Extra large or extra small numbers can be written with scientific (exponential)
notation:

Example

let y = 123e5; // 12300000

let z = 123e-5; // 0.00123

JavaScript Booleans

Booleans can only have two values: true or false.

Example

let x = 5;
let y = 5;
let z = 6;
(x == y) // Returns true
(x == z) // Returns false
Booleans are often used in conditional testing.

JavaScript Arrays

JavaScript arrays are written with square brackets.

Array items are separated by commas.

The following code declares (creates) an array called cars, containing three items (car
names):
Example
const cars = ["Saab", "Volvo", "BMW"];
Array indexes are zero-based, which means the first item is [0], second is [1], and so
on.
79
JavaScript Objects

JavaScript objects are written with curly braces {}.

Object properties are written as name:value pairs, separated by commas.

Example

const person = {firstName:"John", lastName:"Doe", age:50, eyeColor:"blue"};


The object (person) in the example above has 4 properties: firstName, lastName, age,
and eyeColor.

The typeof Operator

You can use the JavaScript typeof operator to find the type of a JavaScript variable.

The typeof operator returns the type of a variable or an expression:

Example

typeof "" // Returns "string"


typeof "John" // Returns "string"
typeof "John Doe" // Returns "string"

Example

typeof 0 // Returns "number"


typeof 314 // Returns "number"
typeof 3.14 // Returns "number"
typeof (3) // Returns "number"
typeof (3 + 4) // Returns "
number"

Undefined

In JavaScript, a variable without a value, has the value undefined. The type is also
undefined.

Example

let car; // Value is undefined, type is undefined

Any variable can be emptied, by setting the value to undefined. The type will also be
undefined.
Example

car = undefined; // Value is undefined, type is undefined

Empty Values

An empty value has nothing to do with undefined.

80
An empty string has both a legal value and a type.

Example

let car = ""; // The value is "", the typeof is "string"

JavaScript Variables

4 Ways to Declare a JavaScript Variable:

 Using var
 Using let
 Using const
 Using nothing

What are Variables?

Variables are containers for storing data (storing data values).

In this example, x, y, and z, are variables, declared with the var keyword:

Example

var x = 5;
var y = 6;
var z = x +
y;

In this example, x, y, and z, are variables, declared with the let keyword:

Example

let x = 5;
let y = 6;
let z = x + y;

In this example, x, y, and z, are undeclared variables:

Example

x = 5;
y = 6;
z = x + y;
From all the examples above, you can guess:

 x stores the value 5


 y stores the value 6
 z stores the value 11

When to Use JavaScript var?

Always declare JavaScript variables with var,let, orconst.


81
The var keyword is used in all JavaScript code from 1995 to 2015.

The let and const keywords were added to JavaScript in 2015.

If you want your code to run in older browser, you must use var.

When to Use JavaScript const?

If you want a general rule: always declare variables with const.

If you think the value of the variable can change, use let.

In this example, price1, price2, and total, are variables:

Example

const price1 = 5;
const price2 = 6;
let total = price1 + price2;

The two variables price1 and price2 are declared with the const keyword.

These are constant values and cannot be changed.

The variable total is declared with the let keyword.

This is a value that can be changed.

Just Like Algebra

Just like in algebra, variables hold values:

let x = 5;
let y = 6;

Just like in algebra, variables are used in expressions:

let z = x + y;

From the example above, you can guess that the total is calculated to be 11.
JavaScript Identifiers

All JavaScript variables must be identified with unique names.

These unique names are called identifiers.

Identifiers can be short names (like x and y) or more descriptive names (age, sum,
totalVolume).

The general rules for constructing names for variables (unique identifiers) are:

82
 Names can contain letters, digits, underscores, and dollar signs.
 Names must begin with a letter
 Names can also begin with $ and _ (but we will not use it in this tutorial)
 Names are case sensitive (y and Y are different variables)
 Reserved words (like JavaScript keywords) cannot be used as names

The Assignment Operator

In JavaScript, the equal sign (=) is an "assignment" operator, not an "equal to"
operator.

This is different from algebra. The following does not make sense in algebra:

x=x+5

In JavaScript, however, it makes perfect sense: it assigns the value of x + 5 to x.

(It calculates the value of x + 5 and puts the result into x. The value of x is
incremented by 5.)

JavaScript Data Types

JavaScript variables can hold numbers like 100 and text values like "John Doe".

In programming, text values are called text strings.

JavaScript can handle many types of data, but for now, just think of numbers and
strings.

Strings are written inside double or single quotes. Numbers are written without
quotes.

If you put a number in quotes, it will be treated as a text string.

Example

const pi = 3.14;
let person = "John Doe";
let answer = 'Yes I am!';
Declaring a JavaScript Variable

Creating a variable in JavaScript is called "declaring" a variable.

You declare a JavaScript variable with the var or the let keyword:

var carName;
or:
let carName;

After the declaration, the variable has no value (technically it is undefined).

To assign a value to the variable, use the equal sign:


83
carName = "Volvo";

You can also assign a value to the variable when you declare it:

let carName = "Volvo";

In the example below, we create a variable called carName and assign the value
"Volvo" to it.

Then we "output" the value inside an HTML paragraph with id="demo":

Example

<p id="demo"></p>

<script>
let carName = "Volvo";
document.getElementById("demo").inne
rHTML = carName;
</script>

One Statement, Many Variables

You can declare many variables in one statement.

Start the statement with let and separate the variables by comma:

Example

let person = "John Doe", carName = "Volvo", price = 200;

A declaration can span multiple lines:

Example

let person = "John Doe",


carName = "Volvo",
price = 200;

Value = undefined

In computer programs, variables are often declared without a value. The value can be
something that has to be calculated, or something that will be provided later, like user
input.

A variable declared without a value will have the value undefined.

The variable carName will have the value undefined after the execution of this
statement:

Example
let carName;
84
Re-Declaring JavaScript Variables

If you re-declare a JavaScript variable declared with var, it will not lose its value.

The variable carName will still have the value "Volvo" after the execution of these
statements:

Example

var carName = "Volvo";


var carName;

JavaScript Arithmetic

As with algebra, you can do arithmetic with JavaScript variables, using operators like
= and +:

Example

let x = 5 + 2 + 3;

You can also add strings, but strings will be concatenated:

Example

let x = "John" + " " + "Doe";

Also try this:

Example: let x = "5" + 2 + 3;


Now try this:

Example: let x = 2 + 3 + "5";

JavaScript Dollar Sign $

Since JavaScript treats a dollar sign as a letter, identifiers containing $ are valid
variable names:

Example
let $ = "Hello World";
let $$$ = 2;
let $myMoney = 5;

Using the dollar sign is not very common in JavaScript, but professional programmers
often use it as an alias for the main function in a JavaScript library.

In the JavaScript library jQuery, for instance, the main function $ is used to select
HTML elements. In jQuery $("p"); means "select all p elements".

JavaScript Underscore (_)


85
Since JavaScript treats underscore as a letter, identifiers containing _ are valid
variable names:
Example

let _lastName = "Johnson";


let _x = 2;
let _100 = 5;
Using the underscore is not very common in JavaScript, but a convention among
professional programmers is to use it as an alias for "private (hidden)" variables.

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).

Example

function myFunction(p1, p2) {


return p1 * p2; // The function returns the product of p1 and p2
}

JavaScript Function Syntax

A JavaScript function is defined with the function keyword, followed by a name,


followed by parentheses ().

Function names can contain letters, digits, underscores, and dollar signs (same rules
as variables).

The parentheses may include parameter names separated by commas:


(parameter1, parameter2, ...)

The code to be executed, by the function, is placed inside curly brackets: {}

function name(parameter1, parameter2, parameter3) {


// code to be executed
}

Function parameters are listed inside the parentheses () in the function definition.

Function arguments are the values received by the function when it is invoked.

Inside the function, the arguments (the parameters) behave as local variables.

A Function is much the same as a Procedure or a Subroutine, in other programming


languages.

Function Invocation

The code inside the function will execute when "something" invokes (calls) the
function:
86
 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":
Example

Calculate the product of two numbers, and return the result:

let x = myFunction(4, 3); // Function is called, return value will end up in x

function myFunction(a, b) {
return a * b; // Function returns the product of a and b
}

The result in x will be:

12

Why Functions?

You can reuse code: Define the code once, and use it many times.

You can use the same code many times with different arguments, to produce different
results.

Example

Convert Fahrenheit to Celsius:

function toCelsius(fahrenheit) {
return (5/9) * (fahrenheit-32);
}
document.getElementById("demo").innerHTML = toCelsius(77);

The () Operator Invokes the Function

Using the example above, toCelsius refers to the function object, and toCelsius()
refers to the function result.

Accessing a function without () will return the function object instead of the function
result.
Example
87
function toCelsius(fahrenheit) {
return (5/9) * (fahrenheit-32);
}
document.getElementById("demo").innerHTML = toCelsius;

Functions Used as Variable Values

Functions can be used the same way as you use variables, in all types of formulas,
assignments, and calculations.
Example

Instead of using a variable to store the return value of a function:

let x = toCelsius(77);
let text = "The temperature is " + x + " Celsius";

You can use the function directly, as a variable value:

let text = "The temperatur


e is " + toCelsius(77) + " Celsius";

Local Variables

Variables declared within a JavaScript function, become LOCAL to the function.

Local variables can only be accessed from within the function.

Example

// code here can NOT use carName

function myFunction() {
let carName = "Volvo";
// code here CAN use carName
}

// code here can NOT use carName

Since local variables are only recognized inside their functions, variables with the
same name can be used in different functions.

Local variables are created when a function starts, and deleted when the function is
completed.

Events

HTML events are "things" that happen to HTML elements.

When JavaScript is used in HTML pages, JavaScript can "react" on these events.

HTML Events
88
An HTML event can be something the browser does, or something a user does.

Here are some examples of HTML events:

 An HTML web page has finished loading


 An HTML input field was changed
 An HTML button was clicked

Often, when events happen, you may want to do something.

JavaScript lets you execute code when events are detected.

HTML allows event handler attributes, with JavaScript code, to be added to HTML
elements.

With single quotes:

<element event='some JavaScript'>

With double quotes:

<element event="some JavaScript">

In the following example, an onclick attribute (with code), is added to a <button>


element:

Example

<button onclick="document.getElementById('demo').innerHTML = Date()">The time


is?</button>

In the example above, the JavaScript code changes the content of the element with
id="demo".

In the next example, the code changes the content of its own element (using
this.innerHTML):

Example

<button onclick="this.innerHTML = Date()">The time is?</button>

JavaScript code is often several lines long. It is more common to see event attributes
calling functions:

Example

<button onclick="displayDate()">The time is?</button>

Common HTML Events

Here is a list of some common HTML events:


89
Event Description
onchange An HTML element has been changed
onclick The user clicks an HTML element
onmouseover The user moves the mouse over an HTML element
onmouseout The user moves the mouse away from an HTML
element onkeydown The user pushes a keyboard key
onload The browser has finished loading the page

JavaScript Event Handlers

Event handlers can be used to handle and verify user input, user actions, and browser
actions:

 Things that should be done every time a page loads


 Things that should be done when the page is closed
 Action that should be performed when a user clicks a button
 Content that should be verified when a user inputs data
 And more ...

Many different methods can be used to let JavaScript work with events:

 HTML event attributes can execute JavaScript code directly


 HTML event attributes can call JavaScript functions
 You can assign your own event handler functions to HTML elements
 You can prevent events from being sent or being handled
 And more ...

AJAX

AJAX is a developer's dream, because you can:

 Update a web page without reloading the page


 Request data from a server - after the page has loaded
 Receive data from a server - after the page has loaded
 Send data to a server - in the background

AJAX Example

<!DOCTYPE html>
<html>
<body>

<div id="demo">
<h1>The XMLHttpRequest Object</h1>
<button type="button" onclick="loadDoc()">Change Content</button>
</div>

<script>
function loadDoc() {
90
var xhttp = new XMLHttpRequest();
xhttp.onreadystatechange = function() {
if (this.readyState == 4 && this.status == 200) {
document.getElementById("demo").innerHTML =
this.responseText;
}
};
xhttp.open("GET", "ajax_info.txt", true);
xhttp.send();
}
</script>

</body>
</html>

AJAX Example Explained

HTML Page

<!DOCTYPE html>
<html>
<body>

<div id="demo">
<h2>Let AJAX change this text</h2>
<button type="button" onclick="loadDoc()">Change Content</button>
</div>

</body>
</html>

The HTML page contains a <div> section and a <button>.

The <div> section is used to display information from a server.

The <button> calls a function (if it is clicked).

The function requests data from a web server and displays it:

Function loadDoc()

function loadDoc() {
var xhttp = new XMLHttpRequest();
xhttp.onreadystatechange = function() {
if (this.readyState == 4 && this.status == 200) {
document.getElementById("demo").innerHTML = this.responseText;
}
};
xhttp.open("GET", "ajax_info.txt", true);

91
xhttp.send();
}

The "ajax_info.txt" file used in the example above, is a simple text file and looks like
this:

<h1>AJAX</h1>
<p>AJAX is not a programming language.</p>
<p>AJAX is a technique for accessing web servers from a web page.</p>
<p>AJAX stands for Asynchronous JavaScript And XML.</p>

What is AJAX?

AJAX = Asynchronous JavaScript And XML.

AJAX is not a programming language.

AJAX just uses a combination of:

 A browser built-in XMLHttpRequest object (to request data from a web


server)
 JavaScript and HTML DOM (to display or use the data)

AJAX is a misleading name. AJAX applications might use XML to transport data, but
it is equally common to transport data as plain text or JSON text.

AJAX allows web pages to be updated asynchronously by exchanging data with a


web server behind the scenes. This means that it is possible to update parts of a web
page, without reloading the whole page.

How AJAX Works

 1. An event occurs in a web page (the page is loaded, a button is clicked)


 2. An XMLHttpRequest object is created by JavaScript
 3. The XMLHttpRequest object sends a request to a web server

92
 4. The server processes the request
 5. The server sends a response back to the web page
 6. The response is read by JavaScript
 7. Proper action (like page update) is performed by JavaScript

GET and POST

The keystone of AJAX is the XMLHttpRequest object.

The XMLHttpRequest Object

All modern browsers support the XMLHttpRequest object.

The XMLHttpRequest object can be used to exchange data with a server behind the
scenes. This means that it is possible to update parts of a web page, without reloading
the whole page.

Create an XMLHttpRequest Object

All modern browsers (Chrome, Firefox, Edge (and IE7+), Safari, Opera) have a built-
in XMLHttpRequest object.

Syntax for creating an XMLHttpRequest object:

variable = new XMLHttpRequest();

Example

var xhttp = new XMLHttpRequest();

The "ajax_info.txt" file used in the example above, is a simple text file and looks like
this:

<h1>AJAX</h1>
<p>AJAX is not a programming language.</p>
<p>AJAX is a technique for accessing web servers from a web page.</p>
<p>AJAX stands for Asynchronous JavaScript And XML.</p>

XMLHttpRequest Object Methods

Method Description
new XMLHttpRequest() Creates a new XMLHttpRequest object
abort() Cancels the current request
getAllResponseHeaders() Returns header information
getResponseHeader() Returns specific header information
Specifies the request
open(method,url,async,user,psw)

93
method: the request type GET or POST
url: the file location
async: true (asynchronous) or false (synchronous)
user: optional user name
psw: optional password
Sends the request to the
send() server Used for GET requests
Sends the request to the server.
send(string) Used for POST requests
setRequestHeader() Adds a label/value pair to the header to be sent

XMLHttpRequest Object Properties

Property Description
Defines a function to be called when the readyState
onreadystatechange property changes
Holds the status of the XMLHttpRequest.
0: request not initialized
readyState 1: server connection established
2: request received
3: processing request
4: request finished and response is ready
responseText Returns the response data as a string
responseXML Returns the response data as XML data
Returns the status-number of a request
200: "OK"
status 403: "Forbidden"
404: "Not Found"
For a complete list go to the Http Messages Reference
statusText Returns the status-text (e.g. "OK" or "Not Found")

The XMLHttpRequest object is used to exchange data with a server.

Send a Request To a Server

To send a request to a server, we use the open() and send() methods of the
XMLHttpRequest object:

xhttp.open("GET", "ajax_info.txt", true);


xhttp.send();
Method Description
Specifies the type of request
open(method, url, async)
method: the type of request: GET or POST
url: the server (file) location

94
async: true (asynchronous) or false (synchronous)
send() Sends the request to the server (used for GET)
send(string) Sends the request to the server (used for POST)

GET or POST?

GET is simpler and faster than POST, and can be used in most cases.

However, always use POST requests when:

 A cached file is not an option (update a file or database on the server).


 Sending a large amount of data to the server (POST has no size limitations).
 Sending user input (which can contain unknown characters), POST is more
robust and secure than GET.

GET Requests

A simple GET request:

Example

xhttp.open("GET", "demo_get.asp", true);


xhttp.send();

In the example above, you may get a cached result. To avoid this, add a unique ID to
the URL:

Example

xhttp.open("GET", "demo_get.asp?t=" + Math.random(), true);


xhttp.send();

If you want to send information with the GET method, add the information to the
URL:

Example

xhttp.open("GET", "demo_get2.asp?fname=Henry&lname=Ford", true);


xhttp.send();

POST Requests

A simple POST request:

Example

xhttp.open("POST", "demo_post.asp", true);


xhttp.send();
To POST data like an HTML form, add an HTTP header with setRequestHeader().
Specify the data you want to send in the send() method:
95
Example

xhttp.open("POST", "demo_post2.asp", true);


xhttp.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
xhttp.send("fname=Henry&lname=Ford");
Method Description
Adds HTTP headers to the request

setRequestHeader(header, value)
header: specifies the header name
value: specifies the header value

The url - A File On a Server

The url parameter of the open() method, is an address to a file on a server:

xhttp.open("GET", "ajax_test.asp", true);

The file can be any kind of file, like .txt and .xml, or server scripting files like .asp
and .php (which can perform actions on the server before sending the response back).

Asynchronous - True or False?

Server requests should be sent asynchronously.

The async parameter of the open() method should be set to true:

xhttp.open("GET", "ajax_test.asp", true);

By sending asynchronously, the JavaScript does not have to wait for the server
response, but can instead:

 execute other scripts while waiting for server response


 deal with the response after the response is ready

The onreadystatechange Property

With the XMLHttpRequest object you can define a function to be executed when the
request receives an answer.

The function is defined in the onreadystatechange property of the


XMLHttpResponse object:
Example

xhttp.onreadystatechange = function() {
if (this.readyState == 4 && this.status == 200) {
document.getElementById("demo").innerHTML = this.responseText;
}
};
xhttp.open("GET", "ajax_info.txt", true);
xhttp.send();
96
The "ajax_info.txt" file used in the example above, is a simple text file and looks like
this:

<h1>AJAX</h1>
<p>AJAX is not a programming language.</p>
<p>AJAX is a technique for accessing web servers from a web page.</p>
<p>AJAX stands for Asynchronous JavaScript And XML.</p>

You will learn more about onreadystatechange in a later chapter.

Synchronous Request

To execute a synchronous request, change the third parameter in the open() method to
false:

xhttp.open("GET", "ajax_info.txt", false);

Sometimes async = false are used for quick testing. You will also find synchronous
requests in older JavaScript code.

Since the code will wait for server completion, there is no need for an
onreadystatechange function:

Example

xhttp.open("GET", "ajax_info.txt", false);


xhttp.send();
document.getElementById("demo").innerHTML = xhttp.responseText;

The onreadystatechange Property

The readyState property holds the status of the XMLHttpRequest.

The onreadystatechange property defines a function to be executed when the


readyState changes.

The status property and the statusText property holds the status of the
XMLHttpRequest object.

Property Description
Defines a function to be called when the readyState property
onreadystatechange changes
Holds the status of the XMLHttpRequest.
0: request not initialized
readyState
status
1: server connection established 2: request received
3: processing request
4: request finished and response is ready 200: "OK"
403: "Forbidden"
404: "Page not found"
97
For a complete list go to the Http Messages Reference
statusText Returns the status-text (e.g. "OK" or "Not Found")

The onreadystatechange function is called every time the readyState changes.

When readyState is 4 and status is 200, the response is ready:

Example

function loadDoc() {
var xhttp = new XMLHttpRequest();
xhttp.onreadystatechange = function() {
if (this.readyState == 4 && this.status == 200) {
document.getElementById("demo").innerHTML =
this.responseText;
}
};
xhttp.open("GET", "ajax_info.txt", true);
xhttp.send();
}

The "ajax_info.txt" file used in the example above, is a simple text file and looks like
this:

<h1>AJAX</h1>
<p>AJAX is not a programming language.</p>
<p>AJAX is a technique for accessing web servers from a web page.</p>
<p>AJAX stands for Asynchronous JavaScript And XML.</p>

The onreadystatechange event is triggered four times (1-4), one time for each change
in the readyState.

Using a Callback Function

A callback function is a function passed as a parameter to another function.


If you have more than one AJAX task in a website, you should create one function for
executing the XMLHttpRequest object, and one callback function for each AJAX
task.

The function call should contain the URL and what function to call when the response
is ready.

Example

loadDoc("url-1", myFunction1);

loadDoc("url-2", myFunction2);

function loadDoc(url, cFunction) {


var xhttp;
xhttp=new XMLHttpRequest();
xhttp.onreadystatechange = function() {
98
if (this.readyState == 4 && this.status == 200) {
cFunction(this);
}
};
xhttp.open("GET", url, true);
xhttp.send();
}

function myFunction1(xhttp) {
// action goes here
}
function myFunction2(xhttp) {
// action goes here
}

Server Response Properties

Property Description
responseText get the response data as a string
responseXML get the response data as XML data

Server Response Methods

Method Description
Returns specific header information from the
getResponseHeader() server resource
Returns all the header information from the server
getAllResponseHeaders() resource

The responseText Property

The responseText property returns the server response as a JavaScript string, and you
can use it accordingly:

Example

document.getElementById("demo").innerHTML = xhttp.responseText;

The responseXML Property

The XML HttpRequest object has an in-built XML parser.

The responseXML property returns the server response as an XML DOM object.

Using this property you can parse the response as an XML DOM object:

Example

99
Request the file cd_catalog.xml and parse the response:

xmlDoc = xhttp.responseXML;
txt = "";
x = xmlDoc.getElementsByTagName("ARTIST");
for (i = 0; i < x.length; i++) {
txt += x[i].childNodes[0].nodeValue + "<br>";
}
document.getElementById("demo").innerHTML = txt;
xhttp.open("GET", "cd_catalog.xml", true);
xhttp.send();

The getAllResponseHeaders() Method

The getAllResponseHeaders() method returns all header information from the server
response.

Example

var xhttp = new XMLHttpRequest();


xhttp.onreadystatechange = function() {
if (this.readyState == 4 && this.status == 200) {
document.getElementById("demo").innerHTML =
this.getAllResponseHeaders();
}
};
The getResponseHeader() Method

The getResponseHeader() method returns specific header information from the


server response.

Example

var xhttp = new XMLHttpRequest();


xhttp.onreadystatechange = function() {
if (this.readyState == 4 && this.status == 200) {
document.getElementById("demo").innerHTML =
this.getResponseHeader("Last-Modified");
}
};
xhttp.open("GET", "ajax_info.txt", true);
xhttp.send();

100

You might also like