HTML 5
HTML 5
DOCTYPE html>
<html>
<head>
<title>Page Title</title>
</head>
<body>
</body>
</html>
The <head> tag in HTML is used to contain metadata and other elements that are
not directly displayed on the web page but are essential for the page's functionality
and behavior. Here's a breakdown of what typically goes inside the <head> tag and
why it's important:
🔹 Purpose of the <head> Tag
   1. Metadata: Provides information about the document, such as its character
      encoding, author, and description.
 <meta charset="UTF-8">
 <meta name="description" content="A tutorial on HTML head tag">
   2. Title of the Page: Sets the title shown in the browser tab.
 <title>My Web Page</title>
   3. Link to Stylesheets: Connects external CSS files to style the page.
 <link rel="stylesheet" href="styles.css">
   4. Scripts: Includes JavaScript files or inline scripts that affect page behavior.
 <script src="script.js"></script>
   5. Favicon: Specifies the icon shown in the browser tab.
 <link rel="icon" href="favicon.ico">
   6. SEO and Social Media Tags: Helps search engines and social platforms
      understand and display your content better.
 <meta name="keywords" content="HTML, head tag, tutorial">
 <meta property="og:title" content="Learn HTML Head Tag">
The <head> tag is crucial for:
      Page setup and configuration
      Styling and scripting
      Search engine optimization (SEO)
      Improving user experience
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
Note: The content inside the <body> section will be displayed in a browser. The
content inside the <title> element will be shown in the browser's title bar or in the
page's tab.
For writing html open text editor, write html code and save the file as .html and set
the encoding as utf-8 and view saved file by clicking on it and viewing it in browser.
All HTML documents must start with a document type declaration: <!DOCTYPE
html>.
The HTML document itself begins with <html> and ends with </html>.
The visible part of the HTML document is between <body> and </body>.
The <!DOCTYPE> declaration represents the document type, and helps browsers to
display web pages correctly.
It must only appear once, at the top of the page (before any HTML tags).
The <!DOCTYPE> declaration is not case sensitive.
Click CTRL + U in an HTML page, or right-click on the page and select "View Page
Source". This will open a new tab containing the HTML source code of the page.
Html element:-
An HTML element is defined by a start tag, some content, and an end tag.
HTML elements can be nested (this means that elements can contain other
elements).
All HTML documents consist of nested HTML elements.
Unexpected results and errors may occur if you forget the end tag!
Html attributes:-
Attributes are always specified in the start tag
<a href="https://www.w3schools.com">Visit W3Schools</a>
Absolute url: src=https://www.w3schools.com/images/img_girl.jpg
Relative url: src="/images/img_girl.jpg"
Tip: It is almost always best to use relative URLs. They will not break if you change
domain.
<img src="img_girl.jpg" width="500" height="600">
The required alt attribute for the <img> tag specifies an alternate text for an
image, if the image for some reason cannot be displayed.
The style attribute is used to add styles to an element, such as color, font, size, and
more
You should always include the lang attribute inside the <html> tag, to declare the
language of the Web page. This is meant to assist search engines and browsers.
<p title="I'm a tooltip">This is a paragraph.</p>
The title attribute defines some extra information about an element.
Use lowercase attribute names
Use quotes for attribute values
The width and height attributes of <img> provide size information for images
Html heading:-
Browsers automatically add some white space (a margin) before and after a heading
Search engines use the headings to index the structure and content of your web
pages
Use HTML headings for headings only. Don't use headings to make text BIG or bold.
<h1 style="font-size:60px;">Heading 1</h1>
Html paragraphs:-
A paragraph always starts on a new line, and browsers automatically add some
white space (a margin) before and after a paragraph.
The browser will automatically remove any extra spaces and lines when the page is
displayed- use pre tag to preserve the extra spaces.
The <hr> tag defines a thematic break in an HTML page, and is most often
displayed as a horizontal rule.
The <hr> tag is an empty tag, which means that it has no end tag.
The HTML <br> element defines a line break.
Use <br> if you want a line break (a new line) without starting a new paragraph
The <br> tag is an empty tag, which means that it has no end tag.
The text inside a <pre> element is displayed in a fixed-width font (usually Courier),
and it preserves both spaces and line breaks
Html styles:-
<tagname style="property:value;">
The property is a CSS property. The value is a CSS value.
The CSS background-color property defines the background color for an HTML
element
The CSS color property defines the text color for an HTML element
The CSS font-family property defines the font to be used for an HTML element
The CSS font-size property defines the text size for an HTML element
The CSS text-align property defines the horizontal text alignment for an HTML
element
The contact information can be an email address, URL, physical address, phone
number, social media handle, etc.
The text in the <address> element usually renders in italic, and browsers will
always add a line break before and after the <address> element.
The HTML <cite> tag defines the title of a creative work (e.g. a book, a poem, a
song, a movie, a painting, a sculpture, etc.).
Note: A person's name is not the title of a work.
The text in the <cite> element usually renders in italic.
<p><cite>The Scream</cite> by Edvard Munch. Painted in 1893.</p>
The HTML <bdo> tag is used to override the current text direction
<bdo dir="rtl">This text will be written from right to left</bdo>
Html comments:-
HTML comments are not displayed in the browser, but they can help document your
HTML source code.
<!-- Write your comments here -->
Notice that there is an exclamation point (!) in the start tag, but not in the end tag.
Comments can be used to hide content.
With comments you can place notifications and reminders in your HTML code
You can also hide more than one line. Everything between the <!-- and the --> will
be hidden from the display.
Html colors:-
<h1 style="background-color:#ff6347;">...</h1>
Where rr (red), gg (green) and bb (blue) are hexadecimal values between 00 and ff
(same as decimal 0-255).
<h1 style="background-color:hsl(9, 100%, 64%);">...</h1>
An RGB color value represents RED, GREEN, and BLUE light sources.
An RGBA color value is an extension of RGB with an Alpha channel (opacity).
Html css:-
CSS stands for Cascading Style Sheets.
CSS saves a lot of work. It can control the layout of multiple web pages all at once.
With CSS, you can control the color, font, the size of text, the spacing between
elements, how elements are positioned and laid out, what background images or
background colors are to be used, different displays for different devices and screen
sizes, and much more!
Tip: The word cascading means that a style applied to a parent element will also
apply to all children elements within the parent. So, if you set the color of the body
text to "blue", all headings, paragraphs, and other text elements within the body
will also get the same color (unless you specify something else)!
CSS can be added to HTML documents in 3 ways:
      Inline - by using the style attribute inside HTML elements
      Internal - by using a <style> element in the <head> section
      External - by using a <link> element to link to an external CSS file
Inline css:-
<h1 style="color:blue;">A Blue Heading</h1>
Internal CSS:-
External css:-
Tip: With an external style sheet, you can change the look of an entire web site, by
changing one file!
Css has color, fon-family, font-size, border, padding, margin etc
Link to external css:
<link rel="stylesheet" href="https://www.w3schools.com/html/styles.css">
Html links:-
HTML links are hyperlinks.
You can click on a link and jump to another document.
When you move the mouse over a link, the mouse arrow will turn into a little hand.
Note: A link does not have to be text. A link can be an image or any other HTML
element!
By default, links will appear as follows in all browsers:
      An unvisited link is underlined and blue
      A visited link is underlined and purple
      An active link is underlined and red
Tip: Links can of course be styled with CSS, to get another look!
The target attribute can have one of the following values:
      _self - Default. Opens the document in the same window/tab as it was clicked
      _blank - Opens the document in a new window or tab
      _parent - Opens the document in the parent frame
      _top - Opens the document in the full body of the window
Use image as link:
<a href="default.asp">
<img src="smiley.gif" alt="HTML tutorial" style="width:42px;height:42px;">
</a>
Link to email address: <a href="mailto:someone@example.com">Send email</a>
Button as a link: <button onclick="document.location='default.asp'">HTML
Tutorial</button>
Link titles: <a href="https://www.w3schools.com/html/" title="Go to W3Schools
HTML section">Visit our HTML Tutorial</a>
Css also has text-decoration
create bookmark:-
<h2 id="C4">Chapter 4</h2>
<a href="#C4">Jump to Chapter 4</a>
You can also add a link to a bookmark on another page:
<a href="html_demo.html#C4">Jump to Chapter 4</a>
Html images:-
<img src="img_girl.jpg" alt="Girl in a jacket">
The HTML <img> tag is used to embed an image in a web page.
Images are not technically inserted into a web page; images are linked to web
pages. The <img> tag creates a holding space for the referenced image.
The <img> tag is empty, it contains attributes only, and does not have a closing
tag.
The <img> tag has two required attributes:
      src - Specifies the path to the image
      alt - Specifies an alternate text for the image
Note: When a web page loads, it is the browser, at that moment, that gets the
image from a web server and inserts it into the page. Therefore, make sure that the
image actually stays in the same spot in relation to the web page, otherwise your
visitors will get a broken link icon. The broken link icon and the alt text are shown if
the browser cannot find the image.
Tip: A screen reader is a software program that reads the HTML code, and allows
the user to "listen" to the content. Screen readers are useful for people who are
visually impaired or learning disabled.
<img src="img_girl.jpg" alt="Girl in a jacket" style="width:500px;height:600px;">
<img src="img_girl.jpg" alt="Girl in a jacket" width="500" height="600">
Note: Always specify the width and height of an image. If width and height are not
specified, the web page might flicker while the image loads.
If you have your images in a sub-folder, you must include the folder name in
the src attribute:
<img src="/images/html5.gif" alt="HTML5
Icon" style="width:128px;height:128px;">
Images on another website/server:
<img src="https://www.w3schools.com/images/w3schools_green.jpg" alt="W3Schoo
ls.com">
Notes on external images: External images might be under copyright. If you do
not get permission to use it, you may be in violation of copyright laws. In addition,
you cannot control external images; they can suddenly be removed or changed.
Animated image:
<img src="programming.gif" alt="Computer
Man" style="width:48px;height:48px;">
<a href="default.asp">
 <img src="smiley.gif" alt="HTML tutorial" style="width:42px;height:42px;">
</a>
<p><img src="smiley.gif" alt="Smiley
face" style="float:right;width:42px;height:42px;">
The image will float to the right of the text.</p>
Image maps:-
An image map is an image with clickable areas. The areas are defined with one or
more <area> tags.
<img src="workplace.jpg" alt="Workplace" usemap="#workmap">
<map name="workmap">
 <area shape="rect" coords="34,44,270,350" alt="Computer" href="computer.htm
">
 <area shape="rect" coords="290,172,333,250" alt="Phone" href="phone.htm">
 <area shape="circle" coords="337,300,44" alt="Coffee" href="coffee.htm">
</map>
<img src="workplace.jpg" alt="Workplace" usemap="#workmap">
The usemap value starts with a hash tag # followed by the name of the image map,
and is used to create a relationship between the image and the image map.
Then, add a <map> element.
The <map> element is used to create an image map, and is linked to the image by
using the required name attribute:
<map name="workmap">
       rect - defines a rectangular region
       circle - defines a circular region
       poly - defines a polygonal region
       default - defines the entire region
<h2>Image Maps</h2>
<map name="workmap">
 <area shape="circle" coords="337,300,44" href="coffee.htm"
onclick="myFunction()">
</map>
<script>
function myFunction() {
 alert("You clicked the coffee cup!");
}
</script>
Background images:-
<p style="background-image: url('img_girl.jpg');">
Background image on page:
If the background image is smaller than the element, the image will repeat itself,
horizontally and vertically, until it reaches the end of the element.
If you want the background image to cover the entire element, you can set
the background-size property to cover.
Also, to make sure the entire element is always covered, set the background-
attachment property to fixed:
If you want the background image to stretch to fit the entire element, you can set
the background-size property to 100% 100%
Picture element:-
The HTML <picture> element allows you to display different pictures for different
devices or screen sizes.
<picture>
 <source media="(min-width: 650px)" srcset="img_food.jpg">
 <source media="(min-width: 465px)" srcset="img_car.jpg">
 <img src="img_girl.jpg">
</picture>
Note: Always specify an <img> element as the last child element of
the <picture> element. The <img> element is used by browsers that do not
support the <picture> element, or if none of the <source> tags match.
There are two main purposes for the <picture> element:
1. Bandwidth
If you have a small screen or device, it is not necessary to load a large image file.
The browser will use the first <source> element with matching attribute values, and
ignore any of the following elements.
2. Format Support
Some browsers or devices may not support all image formats. By using
the <picture> element, you can add images of all formats, and the browser will use
the first format it recognizes, and ignore any of the following elements.
Favicon:-
A favicon is a small image displayed next to the page title in the browser tab.
Tip: A favicon is a small image, so it should be a simple image with high contrast.
To add a favicon to your website, either save your favicon image to the root
directory of your webserver, or create a folder in the root directory called images,
and save your favicon image in this folder. A common name for a favicon image is
"favicon.ico".
Page title:-
The page title is very important for search engine optimization (SEO). The text is
used by search engine algorithms to decide the order when listing pages in search
results.
The <title> element:
      defines a title in the browser toolbar
      provides a title for the page when it is added to favorites
      displays a title for the page in search engine-results
Tables:-
Each table cell is defined by a <td> and a </td> tag.
td stands for table data.
Note: A table cell can contain all sorts of HTML elements: text, images, lists, links,
other tables, etc.
tr stands for table row.
Note: You can have as many rows as you like in a table; just make sure that the
number of cells are the same in each row.
th stands for table header.
By default, the text in <th> elements are bold and centered, but you can change
that with CSS.
Table borders:-
HTML tables can have borders of different styles and shapes.
table, th, td {
  border: 1px solid black;
}
To avoid having double borders like in the example above, set the CSS border-
collapse property to collapse.
Background color: green and border color: white:-
Table sizes:-
HTML tables can have different sizes for each column, row or the entire table.
<table style="width:100%">
Note: Using a percentage as the size unit for a width means how wide will this
element be compared to its parent element, which in this case is
the <body> element.
<th style="width:70%">Firstname</th> sets to 70% of table width
<tr style="height:200px">
Table headers:-
Vertical table headers:-
th {
  text-align: left;
}
<th colspan="2">Name</th> header for multiple columns
Table caption is just the heading of the table:-
Padding and spacing:-
HTML tables can adjust the padding inside the cells, and also the space between the
cells.
Cell padding is the space between the cell edges and the cell content.
By default the padding is set to 0.
th, td {
  padding: 15px;
}
Table styling:-
Zebra stripes:-
Note: If you use (odd) instead of (even), the styling will occur on row 1,3,5 etc.
instead of 2,4,6 etc.
To make vertical zebra stripes, style every other column, instead of every other row:
Set the :nth-child(even) for table data elements
hoverable table:-
tr:hover {background-color: #D6EEEE;}
table colgroup:-
Note: The <colgroup> tag must be a child of a <table> element and should be
placed before any other table elements, like <thead>, <tr>, <td> etc., but after
the <caption> element, if present.
There is only a very limited selection of CSS properties that are allowed to be used
in the colgroup:
width property
visibility property
background properties
border properties
All other CSS properties will have no effect on your tables.
To hide columns:-
Lists :-
HTML lists allow web developers to group a set of related items in lists.
Small black circles by default in unordered lists:-
<ul>
 <li>Coffee</li>
 <li>Tea</li>
 <li>Milk</li>
</ul>
Numbers by default in ordered lists:-
<ol>
 <li>Coffee</li>
 <li>Tea</li>
 <li>Milk</li>
</ol>
A description list is a list of terms, with a description of each term.
The <dl> tag defines the description list, the <dt> tag defines the term (name),
and the <dd> tag describes each term:
<ul style="list-style-type:disc;">  circle, square or none
Nested lists:-
ul {
 list-style-type: none;
 margin: 0;
 padding: 0;
  overflow: hidden;
  background-color: #333333;
}
li {
  float: left;
}
li a {
  display: block;
  color: white;
  text-align: center;
  padding: 16px;
  text-decoration: none;
}
li a:hover {
  background-color: #111111;
}
</style>
</head>
<body>
<ul>
 <li><a   href="#home">Home</a></li>
 <li><a   href="#news">News</a></li>
 <li><a   href="#contact">Contact</a></li>
 <li><a   href="#about">About</a></li>
</ul>
Ordered lists:-
<ol type="1"> A,a,I or i
 <li>Coffee</li>
 <li>Tea</li>
 <li>Milk</li>
</ol>
<ol start="50">
Div:-
The <div> element is used as a container for other HTML elements.
The <div> element is by default a block element, meaning that it takes all available
width, and comes with line breaks before and after.
The <div> element is often used to group sections of a web page together.
If you have a <div> element that is not 100% wide, and you want to center-align it,
set the CSS margin property to auto.
<style>
div {
 width:300px;
 margin:auto;
}
</style>
div {
 width:30%;
 display:inline-block;
}
Css flexbox:-
The CSS Flexbox Layout Module was introduced to make it easier to design flexible
responsive layout structure without using float or positioning.
<style>
.mycontainer {
 display: flex;
}
.mycontainer > div {
 width:33%;
}
</style>
Grid:-
The CSS Grid Layout Module offers a grid-based layout system, with rows and
columns, making it easier to design web pages without having to use floats and
positioning.
Sounds almost the same as flex, but has the ability to define more than one row and
position each row individually.
<style>
.grid-container {
  display: grid;
  grid-template-columns: 33% 33% 33%;
}
</style>
Classes:-
The HTML class attribute is used to specify a class for an HTML element.
The class attribute is often used to point to a class name in a style sheet. It can also
be used by a JavaScript to access and manipulate elements with the specific class
name.
In the following example we have three <div> elements with a class attribute with
the value of "city".
<style>
.city {
  background-color: tomato;
  color: white;
  border: 2px solid black;
  margin: 20px;
  padding: 20px;
}
</style>
<style>
.note {
  font-size: 120%;
  color: red;
}
</style>
</head>
<body>
To define multiple classes, separate the class names with a space, e.g. <div
class="city main">. The element will be styled according to all the classes
specified.
<h2 class="city main">London</h2>
Different elements can share same class for example <h1> and <p> can share
same class.
Use of class attribute in java script:-
<!DOCTYPE html>
<html>
<body>
<h2 class="city">London</h2>
<p>London is the capital of England.</p>
<h2 class="city">Paris</h2>
<p>Paris is the capital of France.</p>
<h2 class="city">Tokyo</h2>
<p>Tokyo is the capital of Japan.</p>
<script>
function myFunction() {
 var x = document.getElementsByClassName("city");
 for (var i = 0; i < x.length; i++) {
    x[i].style.display = "none";
 }
}
</script>
</body>
</html>
Id:-
The HTML id attribute is used to specify a unique id for an HTML element.
You cannot have more than one element with the same id in an HTML document.
<!DOCTYPE html>
<html>
<head>
<style>
#myHeader {
 background-color: lightblue;
 color: black;
 padding: 40px;
 text-align: center;
}
</style>
</head>
<body>
</body>
</html>
<script>
function displayResult() {
 document.getElementById("myHeader").innerHTML = "Have a nice day!";
}
</script>
Iframes:-
An HTML iframe is used to display a web page within a web page.
The HTML <iframe> tag specifies an inline frame.
An inline frame is used to embed another document within the current HTML
document.
Syntax
<iframe src="url" title="description"></iframe>
Tip: It is a good practice to always include a title attribute for the <iframe>. This is
used by screen readers to read out what the content of the iframe is.
<iframe src="demo_iframe.htm" height="200" width="300" title="Iframe
Example"></iframe>
<iframe src="demo_iframe.htm" style="height:200px;width:300px;" title="Iframe
Example"></iframe>
<iframe src="demo_iframe.htm" style="border:none;" title="Iframe
Example"></iframe>
<iframe src="demo_iframe.htm" style="border:2px solid red;" title="Iframe
Example"></iframe>
Iframe – target for a link:
<iframe src="demo_iframe.htm" name="iframe_a" height="300px" width="100%"
title="Iframe Example"></iframe>
<p><a href="https://www.w3schools.com"
target="iframe_a">W3Schools.com</a></p>
Javascript:-
The HTML <script> tag is used to define a client-side script (JavaScript).
The <script> element either contains script statements, or it points to an external
script file through the src attribute.
Common uses for JavaScript are image manipulation, form validation, and dynamic
changes of content.
To select an HTML element, JavaScript most often uses
the document.getElementById() method.
File paths:-
A file path describes the location of a file in a web site's folder structure.
File paths are used when linking to external files, like:
      Web pages
      Images
      Style sheets
      JavaScripts
Absolute filepath:-
<img src="https://www.w3schools.com/images/picture.jpg" alt="Mountain"
style="width:300px">
Relative filepath:-
A relative file path points to a file relative to the current page.
<img src="/images/picture.jpg" alt="Mountain">
It is best practice to use relative file paths (if possible).
When using relative file paths, your web pages will not be bound to your current
base URL. All links will work on your own computer (localhost) as well as on your
current public domain and your future public domains.
Head element:-
The <head> element is a container for metadata (data about data) and is placed
between the <html> tag and the <body> tag.
HTML metadata is data about the HTML document. Metadata is not displayed on the
page.
Metadata typically define the document title, character set, styles, scripts, and
other meta information.
The <link> element defines the relationship between the current document and an
external resource.
The <link> tag is most often used to link to external style sheets:
<link rel="stylesheet" href="mystyle.css">
The <meta> element is typically used to specify the character set, page
description, keywords, author of the document, and viewport settings.
The metadata will not be displayed on the page, but is used by browsers (how to
display content or reload page), by search engines (keywords), and other web
services.
The initial-scale=1.0 part sets the initial zoom level when the page is first loaded by
the browser.
The <base> element specifies the base URL and/or target for all relative URLs in a
page.
The <base> tag must have either an href or a target attribute present, or both.
<base href="https://www.w3schools.com/" target="_blank">
Responsive webpage:-
Responsive web design is about creating web pages that look good on all devices!
A responsive web design will automatically adjust for different screen sizes and
viewports.
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<img src="img_girl.jpg" style="width:100%;">
<img src="img_girl.jpg" style="max-width:100%;height:auto;">
The HTML <picture> element allows you to define different images for different
browser window sizes.
<picture>
 <source srcset="img_smallflower.jpg" media="(max-width: 600px)">
 <source srcset="img_flowers.jpg" media="(max-width: 1500px)">
 <source srcset="flowers.jpg">
 <img src="img_smallflower.jpg" alt="Flowers">
</picture>
<h1 style="font-size:10vw;">Responsive Text</h1>
Viewport is the browser window size. 1vw = 1% of viewport width. If the viewport is
50cm wide, 1vw is 0.5cm.
Computer code:-
<code>
x = 5;
y = 6;
z = x + y;
</code>
<p>Save the document by pressing <kbd>Ctrl + S</kbd></p>
<p><samp>File not found.<br>Press F1 to continue</samp></p>
<pre>
<code>
x = 5;
y = 6;
z = x + y;
</code>
</pre>
<p>The area of a triangle is: 1/2 x <var>b</var> x <var>h</var>,
where <var>b</var> is the base, and <var>h</var> is the vertical height.</p>
Semantic elements:-
A semantic element clearly describes its meaning to both the browser and the
developer.
.browser {
  background: white;
}
</body>
</html>
Charsets:-
To display an HTML page correctly, a web browser must know which character set to
use.
Utf-8 covers almost all characters in the world.
Asciii:
         English letters (A-Z)
      Numbers (0-9)
      Special characters like ! $ + - ( ) @ < >.
ANSI (Windows-1252) was the original Windows character set:
      Identical to ASCII for the first 127 characters
      Special characters from 128 to 159
      Identical to UTF-8 from 160 to 255
ISO-8859-1 was the default character set for HTML 4. This character set supported
256 different character codes. HTML 4 also supported UTF-8.
      Identical to ASCII for the first 127 characters
      Does not use the characters from 128 to 159
      Identical to ANSI and UTF-8 from 160 to 255
The UTF-8 Character Set
      is identical to ASCII for the values from 0 to 127
      Does not use the characters from 128 to 159
      Identical to ANSI and 8859-1 from 160 to 255
      Continues from the value 256 to 10 000 characters
url encode:-
uniform resource locator
A URL is another word for a web address.
A URL can be composed of words (e.g. w3schools.com), or an Internet Protocol (IP)
address (e.g. 192.68.20.50).
Web browsers request pages from web servers by using a URL.
A Uniform Resource Locator (URL) is used to address a document (or other data) on
the web.
scheme://prefix.domain:port/path/filename
      scheme - defines the type of Internet service (most common is http or
       https)
      prefix - defines a domain prefix (default for http is www)
      domain - defines the Internet domain name (like w3schools.com)
      port - defines the port number at the host (default for http is 80)
      path - defines a path at the server (If omitted: the root directory of the site)
      filename - defines the name of a document or resource
URL Encoding
URLs can only be sent over the Internet using the ASCII character-set. If a URL
contains characters outside the ASCII set, the URL has to be converted.
URL encoding converts non-ASCII characters into a format that can be transmitted
over the Internet.
URL encoding replaces non-ASCII characters with a "%" followed by hexadecimal
digits.
URLs cannot contain spaces. URL encoding normally replaces a space with a plus
(+) sign, or %20.
Html vs xhtml:-
XHTML is a stricter, more XML-based version of HTML
What is XHTML?
      XHTML stands for EXtensible HyperText Markup Language
      XHTML is a stricter, more XML-based version of HTML
      XHTML is HTML defined as an XML application
Why XHTML?
XML is a markup language where all documents must be marked up correctly (be
"well-formed").
browsers ignore errors in HTML pages, and try to display the website even if it has
some errors in the markup. So XHTML comes with a much stricter error handling.
The Most Important Differences from HTML
      <!DOCTYPE> is mandatory
      The xmlns attribute in <html> is mandatory
      <html>, <head>, <title>, and <body> are mandatory
      Elements must always be properly nested
      Elements must always be closed
      Elements must always be in lowercase
      Attribute names must always be in lowercase
      Attribute values must always be quoted
      Attribute minimization is forbidden
Forms:-
An HTML form is used to collect user input. The user input is most often sent to a
server for processing.
<form action="/action_page.php">
 <label for="fname">First name:</label><br>
 <input type="text" id="fname" name="fname" value="John"><br>
 <label for="lname">Last name:</label><br>
 <input type="text" id="lname" name="lname" value="Doe"><br><br>
 <input type="submit" value="Submit">
</form>
The <form> element is a container for different types of input elements, such as:
text fields, checkboxes, radio buttons, submit buttons, etc.
The HTML <input> element is the most used form element.
An <input> element can be displayed in many ways, depending on
the type attribute.
Note: The form itself is not visible. Also note that the default width of an input field
is 20 characters.
The <label> tag defines a label for many form elements.
The for attribute of the <label> tag should be equal to the id attribute of
the <input> element to bind them together.
Checkboxes let a user select ZERO or MORE options of a limited number of choices.
The <input type="submit"> defines a button for submitting the form data to a form-
handler.
The form-handler is typically a file on the server with a script for processing input
data.
The form-handler is specified in the form's action attribute.
Notice that each input field must have a name attribute to be submitted.
If the name attribute is omitted, the value of the input field will not be sent at all.
Form attributes:-
The action attribute defines the action to be performed when the form is submitted.
Usually, the form data is sent to a file on the server when the user clicks on the
submit button.
Tip: If the action attribute is omitted, the action is set to the current page.
The target attribute specifies where to display the response that is received after
submitting the form.
Form elements:-
The <input> element can be displayed in several ways, depending on
the type attribute.
<label for="fname">First name:</label>
<input type="text" id="fname" name="fname">
The <label> element defines a label for several form elements.
The for attribute of the <label> tag should be equal to the id attribute of
the <input> element to bind them together.
The <select> element defines a drop-down list:
The <output> element represents the result of a calculation (like one performed by
a script).
Input types:-
The <input type="datetime-local"> specifies a date and time input field, with no
time zone
<input type="image" src="img_submit.gif" alt="Submit" width="48" height="48">
<input type="file" id="myfile" name="myfile">
The <input type="hidden"> defines a hidden input field (not visible to a user).
A hidden field lets web developers include data that cannot be seen or modified by
users when a form is submitted.
A hidden field often stores what database record that needs to be updated when the
form is submitted.
Note: While the value is not displayed to the user in the page's content, it is visible
(and can be edited) using any browser's developer tools or "View Source"
functionality. Do not use hidden inputs as a form of security!
<input type="hidden" id="custId" name="custId" value="3487">
<input type="number" id="quantity" name="quantity" min="1" max="5">
<input type="number" id="quantity" name="quantity" min="0" max="100" step="
10" value="30">
<input type="range" id="vol" name="vol" min="0" max="50">
<input type="search" id="gsearch" name="gsearch">
<input type="tel" id="phone" name="phone" pattern="[0-9]{3}-[0-9]{2}-[0-9]
{3}">
The <input type="url"> is used for input fields that should contain a URL address.
Depending on browser support, the url field can be automatically validated when
submitted.
Some smartphones recognize the url type, and adds ".com" to the keyboard to
match url input.
<input type="week" id="week" name="week">
Input attributes:-
The input value attribute specifies an initial value for an input field
The input readonly attribute specifies that an input field is read-only.
A read-only input field cannot be modified
The value of a read-only input field will be sent when submitting the form!
The input disabled attribute specifies that an input field should be disabled.
A disabled input field is unusable and un-clickable.
The value of a disabled input field will not be sent when submitting the form!
The input size attribute specifies the visible width, in characters, of an input field.
The default value for size is 20.
The input maxlength attribute specifies the maximum number of characters allowed
in an input field.
Note: When a maxlength is set, the input field will not accept more than the
specified number of characters. However, this attribute does not provide any
feedback. So, if you want to alert the user, you must write JavaScript code.
The input min and max attributes specify the minimum and maximum values for an
input field.
Tip: Use the max and min attributes together to create a range of legal values.
The input multiple attribute specifies that the user is allowed to enter more than
one value in an input field.
The multiple attribute works with the following input types: email, and file.
The input pattern attribute specifies a regular expression that the input field's value
is checked against, when the form is submitted.
Tip: Use the global title attribute to describe the pattern to help the user.
<input type="text" id="country_code" name="country_code"
 pattern="[A-Za-z]{3}" title="Three letter country code">
The input placeholder attribute specifies a short hint that describes the expected
value of an input field (a sample value or a short description of the expected
format).
The short hint is displayed in the input field before the user enters a value.
<input type="tel" id="phone" name="phone" placeholder="123-45-678"
pattern="[0-9]{3}-[0-9]{2}-[0-9]{3}"><br><br>
The input required attribute specifies that an input field must be filled out before
submitting the form.
The input step attribute specifies the legal number intervals for an input field.
Tip: This attribute can be used together with the max and min attributes to create a
range of legal values.
Note: Input restrictions are not foolproof, and JavaScript provides many ways to add
illegal input. To safely restrict input, it must also be checked by the receiver (the
server)!
The input autofocus attribute specifies that an input field should automatically get
focus when the page loads.
<input type="text" id="fname" name="fname" autofocus><br>
The input height and width attributes specify the height and width of an <input
type="image"> element.
The input list attribute refers to a <datalist> element that contains pre-defined
options for an <input> element.
The input autocomplete attribute specifies whether a form or an input field should
have autocomplete on or off.
Autocomplete allows the browser to predict the value. When a user starts to type in
a field, the browser should display options to fill in the field, based on earlier typed
values.
Tip: In some browsers you may need to activate an autocomplete function for this
to work (Look under "Preferences" in the browser's menu).
Form attributes:-
The input form attribute specifies the form the <input> element belongs to.
The value of this attribute must be equal to the id attribute of the <form> element
it belongs to.
The input formaction attribute specifies the URL of the file that will process the input
when the form is submitted.
Note: This attribute overrides the action attribute of the <form> element.
The formaction attribute works with the following input types: submit and image.
<form action="/action_page.php">
<input type="submit" formaction="/action_page2.php" value="Submit as Admin">
The input formenctype attribute specifies how the form-data should be encoded
when submitted (only for forms with method="post").
Note: This attribute overrides the enctype attribute of the <form> element.
The input formmethod attribute defines the HTTP method for sending form-data to
the action URL.
Note: This attribute overrides the method attribute of the <form> element.
The input formtarget attribute specifies a name or a keyword that indicates where
to display the response that is received after submitting the form.
Note: This attribute overrides the target attribute of the <form> element.
The input formnovalidate attribute specifies that an <input> element should not be
validated when submitted.
Note: This attribute overrides the novalidate attribute of the <form> element.
<input type="submit" formnovalidate="formnovalidate"
 value="Submit without validation">
The novalidate attribute is a <form> attribute.
When present, novalidate specifies that all of the form-data should not be validated
when submitted.
<form action="/action_page.php" novalidate>
Canvas:-
The HTML <canvas> element is used to draw graphics on a web page.
The graphic to the left is created with <canvas>. It shows four elements: a red
rectangle, a gradient rectangle, a multicolor rectangle, and a multicolor text.
The HTML <canvas> element is used to draw graphics, on the fly, via JavaScript.
The <canvas> element is only a container for graphics. You must use JavaScript to
actually draw the graphics.
<canvas id="myCanvas" width="200" height="100"></canvas>
Note: Always specify an id attribute (to be referred to in a script), and
a width and height attribute to define the size of the canvas. To add a border, use
the style attribute.
<canvas id="myCanvas" width="200" height="100" style="border:1px solid
#000000;">
</canvas>
<script>
var c = document.getElementById("myCanvas");
var ctx = c.getContext("2d");
ctx.moveTo(0, 0);
ctx.lineTo(200, 100);
ctx.stroke();
</script>
<script>
var c = document.getElementById("myCanvas");
var ctx = c.getContext("2d");
ctx.beginPath();
ctx.arc(95, 50, 40, 0, 2 * Math.PI);
ctx.stroke();
</script>
<script>
var c = document.getElementById("myCanvas");
var ctx = c.getContext("2d");
ctx.font = "30px Arial";
ctx.fillText("Hello World", 10, 50);
</script>
<script>
var c = document.getElementById("myCanvas");
var ctx = c.getContext("2d");
// Create gradient
var grd = ctx.createLinearGradient(0, 0, 200, 0);
grd.addColorStop(0, "red");
grd.addColorStop(1, "white");
// Create gradient
var grd = ctx.createRadialGradient(75, 50, 5, 90, 60, 100);
grd.addColorStop(0, "red");
grd.addColorStop(1, "white");
</body>
</html>
<svg width="400" height="120">
 <rect x="10" y="10" width="200" height="100" stroke="red" stroke-width="6" fill
="blue" />
</svg>
<svg width="400" height="180">
 <rect x="50" y="20" rx="20" ry="20" width="150" height="150"
 style="fill:red;stroke:black;stroke-width:5;opacity:0.5" />
</svg>
<svg width="300" height="200">
 <polygon points="100,10 40,198 190,78 10,78 160,198"
 style="fill:lime;stroke:purple;stroke-width:5;fill-rule:evenodd;" />
</svg>
<svg height="130" width="500">
 <defs>
  <linearGradient id="grad1">
    <stop offset="0%" stop-color="yellow" />
    <stop offset="100%" stop-color="red" />
  </linearGradient>
 </defs>
 <ellipse cx="100" cy="70" rx="85" ry="55" fill="url(#grad1)" />
 <text fill="#ffffff" font-size="45" font-family="Verdana" x="50" y="86">SVG</
text>
 Sorry, your browser does not support inline SVG.
</svg>
SVG is a language for describing 2D graphics in XML, while Canvas draws 2D
graphics, on the fly (with JavaScript).
SVG is XML based, which means that every element is available within the SVG
DOM. You can attach JavaScript event handlers to SVG graphics.
In SVG, each drawn shape is remembered as an object. If attributes of an SVG
object are changed, the browser can automatically re-render the shape.
Canvas is rendered pixel by pixel. In canvas, once the graphic is drawn, it is
forgotten by the browser. If its position should be changed, the entire scene needs
to be redrawn, including any objects that might have been covered by the graphic.
Media:-
What is Multimedia?
Multimedia comes in many different formats. It can be almost anything you can
hear or see, like images, music, sound, videos, records, films, animations, and more.
Web pages often contain multimedia elements of different types and formats.
Note: Only MP4, WebM, and Ogg video are supported by the HTML standard.
Note: Only MP3, WAV, and Ogg audio are supported by the HTML standard.
Video:-
The HTML <video> element is used to show a video on a web page.
<video width="400" controls>
 <source src="mov_bbb.mp4" type="video/mp4">
 <source src="mov_bbb.ogg" type="video/ogg">
 Your browser does not support HTML video.
</video>
The controls attribute adds video controls, like play, pause, and volume.
The <source> element allows you to specify alternative video files which the
browser may choose from. The browser will use the first recognized format.
The text between the <video> and </video> tags will only be displayed in browsers
that do not support the <video> element.
<video width="320" height="240" autoplay>
 <source src="movie.mp4" type="video/mp4">
 <source src="movie.ogg" type="video/ogg">
Your browser does not support the video tag.
</video>
Note: Chromium browsers do not allow autoplay in most cases. However, muted
autoplay is always allowed.
<video width="320" height="240" autoplay muted>
 <source src="movie.mp4" type="video/mp4">
 <source src="movie.ogg" type="video/ogg">
Your browser does not support the video tag.
</video>
<!DOCTYPE html>
<html>
<body>
<div style="text-align:center">
 <button onclick="playPause()">Play/Pause</button>
 <button onclick="makeBig()">Big</button>
 <button onclick="makeSmall()">Small</button>
 <button onclick="makeNormal()">Normal</button>
 <br><br>
 <video id="video1" width="420">
  <source src="mov_bbb.mp4" type="video/mp4">
  <source src="mov_bbb.ogg" type="video/ogg">
  Your browser does not support HTML video.
 </video>
</div>
<script>
var myVideo = document.getElementById("video1");
function playPause() {
 if (myVideo.paused)
  myVideo.play();
 else
  myVideo.pause();
}
function makeBig() {
    myVideo.width = 560;
}
function makeSmall() {
    myVideo.width = 320;
}
function makeNormal() {
    myVideo.width = 420;
}
</script>
<p>Video       courtesy    of     <a    href="https://www.bigbuckbunny.org/"
target="_blank">Big Buck Bunny</a>.</p>
</body>
</html>
Audio:-
The HTML <audio> element is used to play an audio file on a web page.
<audio controls>
 <source src="horse.ogg" type="audio/ogg">
 <source src="horse.mp3" type="audio/mpeg">
Your browser does not support the audio element.
</audio>
The text between the <audio> and </audio> tags will only be displayed in browsers
that do not support the <audio> element.
<audio controls autoplay>
 <source src="horse.ogg" type="audio/ogg">
 <source src="horse.mp3" type="audio/mpeg">
Your browser does not support the audio element.
</audio>
<audio controls autoplay muted>
 <source src="horse.ogg" type="audio/ogg">
 <source src="horse.mp3" type="audio/mpeg">
Your browser does not support the audio element.
</audio>
The HTML DOM defines methods, properties, and events for the <audio> element.
This allows you to load, play, and pause audios, as well as set duration and volume.
There are also DOM events that can notify you when an audio begins to play, is
paused, etc.
Plug-ins:-
Plug-ins are computer programs that extend the standard functionality of the
browser.
Plug-ins were designed to be used for many different purposes:
      To run Java applets
      To run Microsoft ActiveX controls
      To display Flash movies
      To display maps
      To scan for viruses
      To verify a bank id
Warning !
Most browsers no longer support Java Applets and Plug-ins.
ActiveX controls are no longer supported in any browsers.
The support for Shockwave Flash has also been turned off in modern browsers.
The <object> element is supported by all browsers.
The <object> element defines an embedded object within an HTML document.
It was designed to embed plug-ins (like Java applets, PDF readers, and Flash
Players) in web pages, but can also be used to include HTML in HTML:
<object width="100%" height="500px" data="snippet.html"></object>
<object data="audi.jpeg"></object>
The <embed> element is supported in all major browsers.
The <embed> element also defines an embedded object within an HTML document.
Web browsers have supported the <embed> element for a long time. However, it
has not been a part of the HTML specification before HTML5.
<embed src="audi.jpeg">
<embed width="100%" height="500px" src="snippet.html">
Youtube:-
The easiest way to play videos in HTML, is to use YouTube.
<iframe width="420" height="345"
src="https://www.youtube.com/embed/tgbNymZ7vqY">
</iframe>
<iframe width="420" height="315"
src="https://www.youtube.com/embed/tgbNymZ7vqY?autoplay=1&mute=1">
</iframe>
Add playlist=videoID and loop=1 to let your video loop forever.
loop=0 (default) - The video will play only once.
loop=1 - The video will loop (forever).
YouTube - Loop forever
<iframe width="420" height="315"
src="https://www.youtube.com/embed/tgbNymZ7vqY?
playlist=tgbNymZ7vqY&loop=1">
</iframe>
Add controls=0 to NOT display controls in the video player.
controls=0 - Player controls does not display.
controls=1 (default) - Player controls is displayed.
YouTube - Controls
<iframe width="420" height="315"
src="https://www.youtube.com/embed/tgbNymZ7vqY?controls=0">
</iframe>
Web api’s:-
A Web API is a developer's dream.
      It can extend the functionality of the browser
      It can greatly simplify complex functions
      It can provide easy syntax to complex code
API stands for Application Programming Interface. An API is some kind of interface
that includes a set of functions and subroutines that allow programmers to access
specific features or data of an application, operating system or other services.
A Web API is an application programming interface for the Web.
1. Geolocation API - This API is used to access the current location of a user (with
latitude and longitude).
2. Drag and Drop API - This API enables you to use drag-and-drop features in
browsers.
3. Web Storage API - This API has mechanisms to let browsers store key/value
pairs (in a more intuitive way than cookies).
4. Web Workers API - This API allows a JavaScript to run in the background,
without affecting the performance of the page. Users can continue to do whatever
they want: clicking, selecting things, etc., while the web worker runs in the
background.
5. Server-Sent Events API - This API allows a web page to automatically get
updates from a server.
6. Canvas API - This API lets you draw graphics, on the fly, via JavaScript.
When implementing an HTML API, you should always:
Check Browser Capability - Always check that the target browsers support the
API. Always add script or message to be run if a browser does not support it.
Add Robust Error Handling - Add robust error handling to take care of scenarios
where an API may not function as expected, to ensure a seamless user experience.
Request User Permission - When using an API that accesses sensitive data, like
the Geolocation API (which will access the user's geographical position), always
prompt the user for consent before proceeding.
Third party APIs are not built into your browser.
To use these APIs, you will have to download the code from the Web.
Examples:
      YouTube API - Allows you to display videos on a web site.
      Twitter API - Allows you to display Tweets on a web site.
      Facebook API - Allows you to display Facebook info on a web site.
Geolocation api:-
The Geolocation API is used to get the user's current location.
Since this can compromise privacy, the location is not available unless the user
approves it.
Note: The Geolocation API is only available on secure contexts such as HTTPS.
Tip: The Geolocation API is most accurate for devices with GPS, like smartphones or
smartwatches.
The Geolocation API is accessed via a call to navigator.geolocation. This will cause
the browser to ask the user for permission to access their location data. If the user
accept, the browser will search for the best available functionality on the device to
access this information (for example GPS).
The getCurrentPosition() method is used to return the user's current location.
function getLocation() {
  if (navigator.geolocation) {
    navigator.geolocation.watchPosition(success, error);
  } else {
    x.innerHTML = "Geolocation is not supported by this browser.";
  }
}
function success(position) {
 x.innerHTML = "Latitude: " + position.coords.latitude +
  "<br>Longitude: " + position.coords.longitude;
}
function error(error) {
  switch(error.code) {
   case error.PERMISSION_DENIED:
    x.innerHTML = "User denied the request for Geolocation."
    break;
   case error.POSITION_UNAVAILABLE:
    x.innerHTML = "Location information is unavailable."
    break;
   case error.TIMEOUT:
    x.innerHTML = "The request to get user location timed out."
    break;
   case error.UNKNOWN_ERROR:
    x.innerHTML = "An unknown error occurred."
    break;
 }
}
</script>
function dragoverHandler(ev) {
  ev.preventDefault();
}
function dropHandler(ev) {
 ev.preventDefault();
  const data = ev.dataTransfer.getData("text");
 ev.target.appendChild(document.getElementById(data));
}
</script>
</head>
<body>
</body>
</html>
<p id="p1" draggable="true">Draggable text</p>
In the example above, the ondragstart attribute of the <img> element calls a
function (dragstartHandler(ev)), that specifies what data to be dragged.
The dataTransfer.setData() method sets the data type and the value of the dragged
data
The ondragover attrribute of the <div> element calls a function
(dragoverHandler(ev)), that specifies where the dragged data can be dropped.
By default, data/elements cannot be dropped in other elements. To allow a drop, we
must prevent the default handling of the element.
This is done by calling the preventDefault() method for the ondragover event:
function dragoverHandler(ev) {
 ev.preventDefault();
}
Code explained:
      Call preventDefault() to prevent the browser default handling of the data
       (default is open as link on drop)
      Get the dragged data with the dataTransfer.getData() method. This method
       will return any data that was set to the same type in the setData() method
      The dragged data is the id of the dragged element ("img1")
      Append the dragged element into the drop element
Web workers:-
A web worker is an external JavaScript file that runs in the background, without
affecting the performance of the page.
<script>
let w;
function startWorker() {
 const x = document.getElementById("result");
 if(typeof(Worker) !== "undefined") {
    if(typeof(w) == "undefined") {
     w = new Worker("demo_workers.js");
    }
    w.onmessage = function(event) {
     x.innerHTML = event.data;
    };
 } else {
    x.innerHTML = "Sorry! No Web Worker support.";
 }
}
function stopWorker() {
 w.terminate();
 w = undefined;
}
</script>
</body>
</html>
Note: Normally web workers are not used for such simple scripts, but for more CPU
intensive tasks!
<script>
const x = document.getElementById("result");
if(typeof(Worker) !== "undefined") {
  x.innerHTML = "Your browser support Web Workers!";
} else {
  x.innerHTML = "Sorry, your browser does not support Web Workers.";
}
</script>
Create a .js Web Worker File
Now, let's create a web worker in an external JavaScript file.
Here we create a script that counts. The script is stored in the "demo_workers.js"
file:
var i = 0;
function timedCount() {
 i = i + 1;
 postMessage(i);
  setTimeout("timedCount()",500);
}
timedCount();
Note: The important part of the code above is the postMessage() method - which is
used to post messages back to the HTML page.
Create a Web Worker Object
Once we have created the .js web worker file, we can call it from an HTML page.
The following lines checks if a worker (w) already exists, if not - it creates a new web
worker object and points to the .js file: "demo_workers.js":
if (typeof(w) == "undefined") {
  w = new Worker("demo_workers.js");
}
Then we can SEND and RETRIEVE messages from the web worker.
Data is sent between web workers and the main thread via a system of messages -
both sides send their messages using the postMessage() method, and respond to
messages via the onmessage event handler.
Add an onmessage event listener to the web worker object.
w.onmessage = function(event){
 document.getElementById("result").innerHTML = event.data;
};
When the web worker in the .js posts a message, the code within the event listener
is executed. The data from the web worker is stored in event.data.
Terminate a Web Worker
When a web worker object is created, it will continue to listen for messages until it is
terminated.
To terminate a web worker object, and free browser/computer resources, use
the terminate() method:
w.terminate();
Reuse the Web Worker
If you set the web worker variable to undefined, after it has been terminated, you
can reuse the worker/code:
w = undefined;
<!DOCTYPE html>
<html>
<body>
<script>
let w;
function startWorker() {
  const x = document.getElementById("result");
  if (typeof(Worker) !== "undefined") {
    if (typeof(w) == "undefined") {
      w = new Worker("demo_workers.js");
    }
    w.onmessage = function(event) {
      x.innerHTML = event.data;
    };
  } else {
    x.innerHTML = "Sorry! No Web Worker support.";
  }
}
function stopWorker() {
  w.terminate();
  w = undefined;
}
</script>
</body>
</html>
Since web workers are in external .js files, they do not have access to the following
JavaScript objects:
      The window object
      The document object
      The parent object