What is HTML?
HTML is a markup language for describing web documents (web
pages).
HTML stands for Hyper Text Markup Language
A markup language is a set of markup tags
HTML documents are described by HTML tags
Each HTML tag describes different document content
A small HTML document:
<!DOCTYPE html>
<html>
<head>
<title>Page Title</title>
</head>
<body>
<h1>My First Heading</h1>
<p>My first paragraph.</p>
</body>
</html>
Example Explained
The DOCTYPE declaration defines the document type to be HTML
The text between <html> and </html> describes an HTML
document
The text between <head> and </head> provides information
about the document
The text between <title> and </title> provides a title for the
document
The text between <body> and </body> describes the visible
page content
The text between <h1> and </h1> describes a heading
The text between <p> and </p> describes a paragraph
Using this description, a web browser can display a document with a
heading and a paragraph
HTML Tags
HTML tags are keywords (tag names) surrounded by angle
brackets:
<tagname>content</tagname>
HTML tags normally come in pairs like <p> and </p>
The first tag in a pair is the start tag, the second tag is the end
tag
The end tag is written like the start tag, but with a slash before
the tag name
The start tag is often called the opening tag.
The end tag is often called the closing tag.
Web Browsers
The purpose of a web browser (Chrome, IE, Firefox, Safari) is to read
HTML documents and display them.
The browser does not display the HTML tags, but uses them to
determine how to display the document:
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>
Only the <body> area (the white area) is displayed by the browser.
The <!DOCTYPE> Declaration
The <!DOCTYPE> declaration helps the browser to display a web page
correctly.
There are different document types on the web.
To display a document correctly, the browser must know both type and
version.
The doctype declaration is not case sensitive. All cases are acceptable:
<!DOCTYPE html>
<!DOCTYPE HTML>
<!doctype html>
<!Doctype Html>
Write HTML Using Notepad or
TextEdit
HTML can be edited by using professional HTML editors like:
Microsoft WebMatrix
Sublime Text
However, for learning HTML we recommend a text editor like Notepad
(PC) or TextEdit (Mac).
We believe using a simple text editor is a good way to learn HTML.
You can use either .htm or .html as file extension. There is no
difference, it is up to you.
HTML Documents
All HTML documents must start with a 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>.
HTML Headings
HTML headings are defined with the <h1> to <h6> tags:
Example
<h1>This is a heading</h1>
<h2>This is a heading</h2>
<h3>This is a heading</h3>
HTML Paragraphs
HTML paragraphs are defined with the <p> tag:
Example
<p>This is a paragraph.</p>
<p>This is another paragraph.</p>
HTML Links
HTML links are defined with the <a> tag:
Example
<a href="http://www.w3schools.com">This is a link</a>
The link's destination is specified in the href attribute.
Attributes are used to provide additional information about HTML
elements.
HTML Images
HTML images are defined with the <img> tag.
The source file (src), alternative text (alt), and size
(width and height) are provided as attributes:
Example
<img src="w3schools.jpg" alt="W3Schools.com" width="104" hei
ght="142">
HTML Element
HTML documents are made up by HTML elements.
HTML Elements
HTML elements are written with a start tag, with an end tag, with
the content in between:
<tagname>content</tagname>
The HTML element is everything from the start tag to the end tag:
<p>My first HTML paragraph.</p>
Nested HTML Elements
HTML elements can be nested (elements can contain elements).
All HTML documents consist of nested HTML elements.
This example contains 4 HTML elements:
Example
<!DOCTYPE html>
<html>
<body>
<h1>My First Heading</h1>
<p>My first paragraph.</p>
</body>
</html>
HTML Example Explained
The <html> element defines the whole document.
It has a start tag <html> and an end tag </html>.
The element content is another HTML element (the <body> element).
<html>
<body>
<h1>My First Heading</h1>
<p>My first paragraph.</p>
</body>
</html>
The <body> element defines the document body.
It has a start tag <body> and an end tag </body>.
The element content is two other HTML elements (<h1> and <p>).
<body>
<h1>My First Heading</h1>
<p>My first paragraph.</p>
</body>
The <h1> element defines a heading.
It has a start tag <h1> and an end tag </h1>.
The element content is: My First Heading.
<h1>My First Heading</h1>
The <p> element defines a paragraph.
It has a start tag <p> and an end tag </p>.
The element content is: My first paragraph.
<p>My first paragraph.</p>
Don't Forget the End Tag
Some HTML elements will display correctly, even if you forget the end
tag:
Example
<html>
<body>
<p>This is a paragraph
<p>This is a paragraph
</body>
</html>
The example above works in all browsers, because the closing tag is
considered optional.
Never rely on this. It might produce unexpected results and/or errors if
you forget the end tag.
Empty HTML Elements
HTML elements with no content are called empty elements.
<br> is an empty element without a closing tag (the <br> tag defines
a line break).
Empty elements can be "closed" in the opening tag like this: <br />.
HTML5 does not require empty elements to be closed. But if you want
stricter validation, or you need to make your document readable by
XML parsers, you should close all HTML elements.
HTML Tip: Use Lowercase Tags
HTML tags are not case sensitive: <P> means the same as <p>.
The HTML5 standard does not require lowercase tags,
HTML Attributes
HTML elements can have attributes
Attributes provide additional information about an element
Attributes are always specified in the start tag
Attributes come in name/value pairs like: name="value"
The lang Attribute
The document language can be declared in the <html> tag.
The language is declared in the lang attribute.
Declaring a language is important for accessibility applications
(screen readers) and search engines:
<!DOCTYPE html>
<html lang="en-US">
<body>
<h1>My First Heading</h1>
<p>My first paragraph.</p>
</body>
</html>
The first two letters specify the language (en). If there is a
dialect, use two more letters (US).
The title Attribute
HTML paragraphs are defined with the <p> tag.
In this example, the <p> element has a title attribute. The value of
the attribute is "About W3Schools":
Example
<p title="About W3Schools">
W3Schools is a web developer's site.
It provides tutorials and references covering
many aspects of web programming,
including HTML, CSS, JavaScript, XML, SQL, PHP, ASP, etc.
</p>
When you move the mouse over the element, the title will be displayed
as a tooltip.
The href Attribute
HTML links are defined with the <a> tag. The link address is specified
in the href attribute:
Example
<a href="http://www.w3schools.com">This is a link</a>
Try it Yourself
Size Attributes
HTML images are defined with the <img> tag.
The filename of the source (src), and the size of the image
(width and height) are all provided asattributes:
Example
<img src="w3schools.jpg" width="104" height="142">
Try it Yourself
The image size is specified in pixels: width="104" means 104 screen
pixels wide.
The alt Attribute
The alt attribute specifies an alternative text to be used, when an
HTML element cannot be displayed.
The value of the attribute can be read by "screen readers". This way,
someone "listening" to the webpage, i.e. a blind person, can "hear" the
element.
Example
<img src="w3schools.jpg" alt="W3Schools.com" width="104" hei
ght="142">
We Suggest: Always Use Lowercase
Attributes
The HTML5 standard does not require lower case attribute names.
The title attribute can be written with upper or lower case
like Title and/or TITLE.
W3C recommends lowercase in HTML4, and demands lowercase for
stricter document types like XHTML.
Lower case is the most common. Lower case is easier to type.
We Suggest: Always Quote
Attribute Values
The HTML5 standard does not require quotes around attribute values.
The href attribute, demonstrated above, can be written as:
Example
<a href=http://www.w3schools.com>
Single or Double Quotes?
Double style quotes are the most common in HTML, but single style
can also be used.
In some situations, when the attribute value itself contains double
quotes, it is necessary to use single quotes:
<p title='John "ShotGun" Nelson'>
Or vice versa:
<p title="John 'ShotGun' Nelson">
Chapter Summary
All HTML elements can have attributes
The HTML title attribute provides additional "tool-tip" information
The HTML href attribute provides address information for links
The HTML width and height attributes provide size information
for images
The HTML alt attribute provides text for screen readers
At W3Schools we always use lowercase HTML attribute names
At W3Schools we always quote attributes with double quotes
HTML Attributes
Below is an alphabetical list of some attributes often used in
HTML:
Attribute
Description
alt
Specifies an alternative text for an image
disabled
Specifies that an input element should be disabled
href
Specifies the URL (web address) for a link
id
Specifies a unique id for an element
src
Specifies the URL (web address) for an image
style
Specifies an inline CSS style for an element
title
Specifies extra information about an element
(displayed as a tool tip)
HTML Headings
Headings are defined with the <h1> to <h6> tags.
<h1> defines the most important heading. <h6> defines the least
important heading.
Example
<h1>This is a heading</h1>
<h2>This is a heading</h2>
<h3>This is a heading</h3>
Note: Browsers automatically add some empty space (a margin)
before and after each heading.
Headings Are Important
Use HTML headings for headings only. Don't use headings to make
text BIG or bold.
Search engines use your headings to index the structure and content
of your web pages.
Users skim your pages by its headings. It is important to use headings
to show the document structure.
h1 headings should be main headings, followed by h2 headings, then
the less important h3, and so on.
HTML Horizontal Rules
The <hr> tag creates a horizontal line in an HTML page.
The hr element can be used to separate content:
Example
<p>This is a paragraph.</p>
<hr>
<p>This is a paragraph.</p>
<hr>
<p>This is a paragraph.</p>
The hr tag defines a horizontal rule:
This is a paragraph.
This is a paragraph.
This is a paragraph.
The HTML <head> Element
The HTML <head> element has nothing to do with HTML headings.
The HTML <head> element contains meta data. Meta data are not
displayed.
The HTML <head> element is placed between the <html> tag and the
<body> tag:
Example
<!DOCTYPE html>
<html>
<head>
<title>My First HTML</title>
<meta charset="UTF-8">
</head>
<body>
The HTML <title> Element
The HTML <title> element is meta data. It defines the HTML
document's title.
The title will not be displayed in the document, but might be displayed
in the browser tab.
The HTML <meta> Element
The HTML <meta> element is also meta data.
It can be used to define the character set, and other information about
the HTML document.
More Meta Elements
In the chapter about HTML styles you discover more meta elements:
The HTML <style> element is used to define internal CSS style
sheets.
The HTML <link> element is used to define external CSS style sheets.
It can be used to define the character set, and other information about
the HTML document.
HTML Tag Reference
W3Schools' tag reference contains additional information about these
tags and their attributes.
You will learn more about HTML tags and attributes in the next
chapters of this tutorial.
Tag
Description
<html>
Defines an HTML document
<body>
Defines the document's body
<head>
Defines the document's head element
<h1> to <h6>
Defines HTML headings
<hr>
Defines a horizontal line
HTML Paragraph
HTML documents are divided into paragraphs.
HTML Paragraphs
The HTML <p> element defines a paragraph.
Example
<p>This is a paragraph</p>
<p>This is another paragraph</p>
Browsers automatically add some white space before and after a
paragraph
HTML Display
You cannot be sure how HTML will be displayed.
Large or small screens, and resized windows will create different
results.
With HTML, you cannot change the output by adding extra spaces or
extra lines in your HTML code.
The browser will remove extra spaces and extra lines when the page is
displayed.
Any number of spaces, and any number of new lines, count as only
one space.
HTML Line Breaks
The HTML <br> element defines a line break.
Use <br> if you want a line break (a new line) without starting a new
paragraph:
Example
<p>This is<br>a para<br>graph with line breaks</p>
This is
a para
graph with line breaks
The <br> element is an empty HTML element. It has no end tag.
The HTML <pre> Element
The HTML <pre> element defines preformatted text.
The text inside a <pre> element is displayed in a fixed-width font
(usually Courier), and it preserves both spaces and line breaks:
Example
<pre>
My Bonnie lies over the ocean.
My Bonnie lies over the sea.
My Bonnie lies over the ocean.
output
The pre tag preserves both spaces and line breaks:
My Bonnie lies over the ocean.
My Bonnie lies over the sea.
My Bonnie lies over the ocean.
Oh, bring back my Bonnie to me.
Oh, bring back my Bonnie to me.
</pre>
HTML Tag Reference
W3Schools' tag reference contains additional information about HTML
elements and their attributes.
Tag
Description
<p>
Defines a paragraph
<br>
Inserts a single line break
<pre>
Defines pre-formatted text
The HTML Style Attribute
Setting the style of an HTML element, can be done with the style
attribute.
The HTML style attribute has the following syntax:
style="property:value;"
The property is a CSS property. The value is a CSS value.
HTML Background Color
The background-color property defines the background color for an
HTML element:
This example sets the background for a page to lightgrey:
Example
<body style="background-color:lightgrey;">
<h1>This is a heading</h1>
<p>This is a paragraph.</p>
</body>
HTML Text Color
The color property defines the text color for an HTML element:
Example
<h1 style="color:blue;">This is a heading</h1>
<p style="color:red;">This is a paragraph.</p>
Try it Yourself
HTML Fonts
The font-family property defines the font to be used for an HTML
element:
Example
<h1 style="font-family:verdana;">This is a heading</h1>
<p style="font-family:courier;">This is a paragraph.</p>
HTML Text Size
The font-size property defines the text size for an HTML element:
Example
<h1 style="font-size:300%;">This is a heading</h1>
<p style="font-size:160%;">This is a paragraph.</p>
HTML Text Alignment
The text-align property defines the horizontal text alignment for an
HTML element:
Example
<h1 style="text-align:center;">Centered Heading</h1>
<p>This is a paragraph.</p>
Chapter Summary
Use the style attribute for styling HTML elements
Use background-color for background color
Use color for text colors
Use font-family for text fonts
Use font-size for text sizes
Use text-align for text alignment
HTML Formatting Elements
In the previous chapter, you learned about HTML styling, using the
HTML style attribute.
HTML also defines special elements for defining text with a
special meaning.
HTML uses elements like <b> and <i> for formatting output,
like bold or italic text.
Formatting elements were designed to display special types of text:
Bold text
Important text
Italic text
Emphasized text
Marked text
Small text
Deleted text
Inserted text
Subscripts
Superscripts
HTML Bold and Strong Formatting
The HTML <b> element defines bold text, without any extra
importance.
Example
<p>This text is normal.</p>
<p><b>This text is bold</b>.</p>
HTML Italic and Emphasized Format
ting
The HTML <i> element defines italic text, without any extra
importance.
Example
<p>This text is normal.</p>
<p><i>This text is italic</i>.</p>
HTML
Small
Formatting
The HTML <small> element defines small text:
Example
<h2>HTML <small>Small</small> Formatting</h2>
HTML Marked Formatting
The HTML <mark> element defines marked or highlighted text:
Example
<h2>HTML <mark>Marked</mark> Formatting</h2>
HTML Marked Formatting
HTML Deleted Formatting
The HTML <del> element defines deleted (removed) text.
Example
<p>My favorite color is <del>blue</del> red.</p>
HTML Inserted Formatting
The HTML <ins> element defines inserted (added) text.
Example
<p>My favorite <ins>color</ins> is red.</p>
My favourite color is red.
HTML
Subscript
Formatting
The HTML <sub> element defines subscripted text.
Example
<p>This is <sub>subscripted</sub> text.</p>
HTML
Superscript
Formatting
The HTML <sup> element defines superscripted text.
Example
<p>This is <sup>superscripted</sup> text.</p>
HTML Text Formatting Elements
Tag
Description
<b>
Defines bold text
<em>
Defines emphasized text
<i>
Defines italic text
<small>
Defines smaller text
<strong>
Defines important text
<sub>
Defines subscripted text
<sup>
Defines superscripted text
<ins>
Defines inserted text
<del>
Defines deleted text
<mark>
Defines marked/highlighted text
HTML <q> for Short Quotations
The HTML <q> element defines a short quotation.
Browsers usually insert quotation marks around the <q> element.
Example
<p>WWF's goal is to: <q>Build a future where people live in
harmony with nature.</q></p>
WWF's goal is to: Build a future where people live in harmony with nature.
HTML <blockquote> for Long
Quotations
The HTML <blockquote> element defines a quoted section.
Browsers usually indent <blockquote> elements.
Example
<p>Here is a quote from WWF's website:</p>
<blockquote cite="http://www.worldwildlife.org/who/index.html">
For 50 years, WWF has been protecting the future of nature.
The world's leading conservation organization,
WWF works in 100 countries and is supported by
1.2 million members in the United States and
close to 5 million globally.
</blockquote>
HTML <abbr> for Abbreviations
The HTML <abbr> element defines an abbreviation or an acronym.
Marking abbreviations can give useful information to browsers,
translation systems and search-engines.
Example
<p>The <abbr title="World Health
Organization">WHO</abbr> was founded in 1948.</p>
HTML <address> for Contact
Information
The HTML <address> element defines contact information
(author/owner) of a document or article.
The <address> element is usually displayed in italic. Most browsers
will add a line break before and after the element.
Example
<address>
Written by John Doe.<br>
Visit us at:<br>
Example.com<br>
Box 564, Disneyland<br>
USA
</address>
HTML <cite> for Work Title
The HTML <cite> element defines the title of a work.
Browsers usually display <cite> elements in italic.
Example
<p><cite>The Scream</cite> by Edvard Munch. Painted in
1893.</p>
Try it Yourself
HTML <bdo> for Bi-Directional
Override
The HTML <bdo> element defines bi-directional override.
The <bdo> element is used to override the current text direction:
Example
<bdo dir="rtl">This text will be written from right to left</bdo>
HTML Quotation and Citation
Elements
Tag
Description
<abbr>
Defines an abbreviation or acronym
<address>
Defines contact information for
the author/owner of a document
<bdo>
Defines the text direction
<blockquote>
Defines a section that is quoted from another source
<cite>
Defines the title of a work
<q>
Defines a short inline quotation
HTML Comment Tags
You can add comments to your HTML source by using the following
syntax:
<!-- Write your comments here -->
Note: There is an exclamation point (!) in the opening tag, but not in the clo
Comments are not displayed by the browser, but they can help
document your HTML.
With comments you can place notifications and reminders in your
HTML:
Example
<!-- This is a comment -->
<p>This is a paragraph.</p>
<!-- Remember to add more information here -->
Comments are also great for debugging HTML, because you can
comment out HTML lines of code, one at a time, to search for errors
HTML Colors
TVs and computer screens
display colors by combining Red, Green, and Blue light.
Color Names
With CSS, colors can be set by using color names:
Styling HTML with CSS
CSS stands for Cascading Style Sheets
Styling can be added to HTML elements in 3 ways:
Inline - using a style attribute in HTML elements
Internal - using a <style> element in the HTML <head> section
External - using one or more external CSS files
The most common way to add styling, is to keep the styles in separate
CSS files. But, in this tutorial, we use internal styling, because it is
easier to demonstrate, and easier for you to try it yourself.