HTML-Chapter 1 - 4
HTML-Chapter 1 - 4
HTML Introduction
HTML is the standard markup language for creating Web
pages. With HTML you can create your own Website.
What is HTML?
    HTML stands for Hyper Text Markup Language
    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.
       A Simple HTML Document
     <!DOCTYPE html>
     <html>
     <head>
     <title>Page Title</title>
     </head>
     <body>
     <h1>My First Heading</h1>
     <p>My first paragraph.</p>
     </body>
     </html>
                                                 1
 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.
                                                  2
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>
                                    4
HTML Attributes
HTML attributes provide additional information about
HTML elements.
HTML Attributes
      All HTML elements can have attributes
      Attributes provide additional information about elements
      Attributes are always specified in the start tag
      Attributes usually come in name/value pairs like: name="value"
          Example
          <a href="https://www.w3schools.com">Visit W3Schools</a>
Tip: It is almost always best to use relative URLs. They will not break if
you change domain.
Example
<img src="img_girl.jpg" width="500" height="600">
Example
<img src="img_girl.jpg" alt="Girl with a jacket">
Example
<p style="color:red;">This is a red paragraph.</p>
                                                                             6
The lang Attribute
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.
<!DOCTYPE html>
<html lang="en">
<body>
...
</body>
</html>
<!DOCTYPE html>
<html lang="en-US">
<body>
...
</body>
</html>
The value of the title attribute will be displayed as a tooltip when you
mouse over the element:
Example
<p title="I'm a tooltip">This is a paragraph.</p>
Good:
<a href="https://www.w3schools.com/html/">Visit our HTML
tutorial</a>
Bad:
<a href=https://www.w3schools.com/html/>Visit our HTML tutorial</a>
Section Summary
      All HTML elements can have attributes
      The href attribute of <a> specifies the URL of the page the link
       goes to
      The src attribute of <img> specifies the path to the image to be
       displayed
      The width and height attributes of <img> provide size
       information for images
      The alt attribute of <img> provides an alternate text for an
       image
      The style attribute is used to add styles to an element, such
       as color, font, size, and more
      The lang attribute of the <html> tag declares the language of
       the
       Web page
      The title attribute defines some extra information about
       an element
HTML Headings
HTML headings are titles or subtitles that you want to display on a
webpage.
                                                                          8
Example
Heading 1
Heading 2
Heading 3
Heading 4
Heading 5
Heading 6
HTML Headings
HTML headings are defined with the <h1> to <h6> tags.
<h1> defines the most important heading. <h6> defines the least
important heading.
Example
<h1>Heading   1</h1>
<h2>Heading   2</h2>
<h3>Heading   3</h3>
<h4>Heading   4</h4>
<h5>Heading   5</h5>
<h6>Heading   6</h6>
Bigger Headings
Each HTML heading has a default size. However, you can specify the size
for any heading with the style attribute, using the CSS font-size
property:
                                                                      9
Example
<h1 style="font-size:60px;">Heading 1</h1>
HTML Paragraphs
A paragraph always starts on a new line, and is usually a block of text.
Example
<p>This is a paragraph.</p>
<p>This is another paragraph.</p>
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 display by adding extra spaces or
extra lines in your HTML code.
The browser will automatically remove any extra spaces and lines when
the page is displayed:
Example
<p>
This paragraph
contains a lot of lines
in the source code,
but the browser
ignores it.
</p>
                                                                            10
<p>
This paragraph
contains         a lot of spaces
in the source          code,
but the        browser
ignores it.
</p>
Example
<h1>This is heading 1</h1>
<p>This is some text.</p>
<hr>
<h2>This is heading 2</h2>
<p>This is some other text.</p>
<hr>
The <hr> tag is an empty tag, which means that it has no end tag.
Use <br> if you want a line break (a new line) without starting a
new paragraph:
Example
<p>This is<br>a paragraph<br>with line breaks.</p>
The <br> tag is an empty tag, which means that it has no end
tag.
                                                                       11
  The Poem Problem
  This poem will display on a single line:
  Example
  <p>
    My Bonnie lies over the ocean.
  Solution - The
  HTML <pre>
  Element
  The HTML <pre> element defines
  Example
  preformatted text.
Exercise:
Use the correct HTML tag to add a
paragraph with the text "Hello
World!".
                                                                            12
<html>
<body>
</body>
</html>
  HTML Styles
  The HTML style attribute is used to add styles to an element, such as
  color, font, size, and more.
  Example
  I am Red
I am Blue
                                                                      13
I am Big
The HTML Style Attribute
Setting the style of an HTML element, can be done with
the style attribute.
<tagname style="property:value;">
Background Color
The CSS background-color property defines the background color for an
HTML element.
Example
Set the background color for a page to powderblue:
<body style="background-color:powderblue;">
<h1>This is a heading</h1>
<p>This is a paragraph.</p>
</body>
Example
Set background color for two different elements:
<body>
</body>
                                                                        14
Text Color
The CSS 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>
Fonts
The CSS 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>
Text Size
The CSS 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>
Text Alignment
The CSS text-align property defines the horizontal text alignment for an
HTML element:
Example
<h1 style="text-align:center;">Centered Heading</h1>
<p style="text-align:center;">Centered paragraph.</p>
                                                                           15
Section 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
Example
This text is bold
Example
<strong>This text is important!</strong>
Tip: The <i> tag is often used to indicate a technical term, a phrase
from another language, a thought, a ship name, etc.
Example
<i>This text is italic</i>
The HTML <em> element defines emphasized text. The content inside
is typically displayed in italic.
Example
<em>This text is emphasized</em>
Example
<small>This is some smaller text.</small>
                                                                        17
HTML <mark> Element
The HTML <mark> element defines text that should be marked
or highlighted:
Example
<p>Do not forget to buy <mark>milk</mark> today.</p>
Example
<p>My favorite color is <del>blue</del> red.</p>
Example
<p>My favorite color is <del>blue</del> <ins>red</ins>.</p>
Example
<p>This is <sub>subscripted</sub> text.</p>
                                                                            18
HTML <sup> Element
The HTML <sup> element defines superscript text. Superscript text
appears half a character above the normal line, and is sometimes
rendered in a smaller font. Superscript text can be used for footnotes,
like WWW[1]:
Example
<p>This is <sup>superscripted</sup> text.</p>
                                                                          19
<sup>                Defines superscripted text
Example
Here is a quote from WWF's website:
For nearly 60 years, WWF has been protecting the future of nature. The
world's leading conservation organization, WWF works in 100 countries
and is supported by more than one million members in the United States
and close to five million globally.
                                                                      20
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>
Tip: Use the global title attribute to show the description for the
abbreviation/acronym when you mouse over the element.
Example
<p>The <abbr title="World Health Organization">WHO</abbr> was
founded in 1948.</p>
                                                                        21
HTML <address> for Contact
Information
The HTML <address> tag defines the contact information for
the author/owner of a document or an article.
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> tag defines the title of a creative work (e.g. a book,
a poem, a song, a movie, a painting, a sculpture, etc.).
Example
The text in the <cite>   element usually renders in italic.
The HTML <bdo> tag is used to override the current text direction:
                                                                         22
  Example
  <bdo dir="rtl">This text will be written from right to
  left</bdo>
Exercise:
Use an HTML element to add quotation marks around the letters "cool".
<p>
I am so           cool           .
</p>
                                                                           23
<q>                     Defines a short inline quotation
HTML Comments
HTML comments are not displayed in the browser, but they can help
document your HTML source code.
Notice that there is an exclamation point (!) in the start tag, but not
in the end tag.
Note: Comments are not displayed by the browser, but they can help
document your HTML source code.
With comments you can place notifications and reminders in your HTML
code:
Example
<!-- This is a comment -->
<p>This is a paragraph.</p>
Comments are also great for debugging HTML, because you can comment
out HTML lines of code, one at a time, to search for errors:
Example
                                                                          24
<!-- Do not display this image at the moment
<img border="0" src="pic_trulli.jpg" alt="Trulli">
-->
HTML Colors
HTML colors are specified with predefined color names, or with RGB,
HEX, HSL, RGBA, or HSLA values.
Color Names
In HTML, a color can be specified by using a color name:
Tomato
Orange
DodgerBlue
MediumSeaGreen
Gray
SlateBlue
                                                                      25
Violet
LightGray
Background Color
You can set the background color for HTML elements:
Hello World
Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam
nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat
volutpat. Ut wisi enim ad minim veniam, quis nostrud exerci tation
ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat.
Example
<h1 style="background-color:DodgerBlue;">Hello World</h1>
<p style="background-color:Tomato;">Lorem ipsum...</p>
Text Color
You can set the color of text:
Hello World
                                                                         26
Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam
nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat
volutpat.
Example
<h1 style="color:Tomato;">Hello World</h1>
<p style="color:DodgerBlue;">Lorem ipsum...</p>
<p style="color:MediumSeaGreen;">Ut wisi enim...</p>
Border Color
You can set the color of borders:
Hello World
Hello World
Hello World
Example
<h1 style="border:2px solid Tomato;">Hello World</h1>
<h1 style="border:2px solid DodgerBlue;">Hello World</h1>
<h1 style="border:2px solid Violet;">Hello World</h1>
Color Values
In HTML, colors can also be specified using RGB values, HEX values, HSL
values, RGBA values, and HSLA values.
The following three <div> elements have their background color set with
RGB, HEX, and HSL values:
                                                                       27
rgb(255, 99, 71)
#ff6347
Example
<h1 style="background-color:rgb(255, 99, 71);">...</h1>
<h1 style="background-color:#ff6347;">...</h1>
<h1 style="background-color:hsl(9, 100%, 64%);">...</h1>
HTML Links
Links are found in nearly all web pages. Links allow users to click their
way from page to page.
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!
                                                                        28
HTML Links - Syntax
The HTML <a> tag defines a hyperlink. It has the following syntax:
The link text is the part that will be visible to the reader.
Clicking on the link text, will send the reader to the specified URL
address.
Example
This example shows how to create a link to W3Schools.com:
Tip: Links can of course be styled with CSS, to get another look!
values:
Example
<h2>Absolute URLs</h2>
<p><a href="https://www.w3.org/">W3C</a></p>
<p><a href="https://www.google.com/">Google</a></p>
<h2>Relative URLs</h2>
<p><a href="html_images.asp">HTML Images</a></p>
<p><a href="/css/default.asp">CSS Tutorial</a></p>
Example
<a href="mailto:someone@example.com">Send email</a>
Button as a Link
To use an HTML button as a link, you have to add some JavaScript code.
                                                                     30
JavaScript allows you to specify what happens at certain events, such
as a click of a button:
Example
<button onclick="document.location='default.asp'">HTML
Tutorial</button>
Link Titles
The title attribute specifies extra information about an element. The
information is most often shown as a tooltip text when the mouse moves
over the element.
Example
<a href="https://www.w3schools.com/html/" title="Go to W3Schools
HTML section">Visit our HTML Tutorial</a>
Section Summary
      Use the <a> element to define a link
      Use the href attribute to define the link address
      Use the target attribute to define where to open the
       linked document
      Use the <img> element (inside <a>) to use an image as a
       link
      Use the mailto: scheme inside the href attribute to create a
       link that opens the user's email program
Example
Here, an unvisited link will be green with no underline. A visited link will
be pink with no underline. An active link will be yellow and underlined.
In addition, when mousing over a link (a:hover) it will become red and
underlined:
<style>
a:link {
  color:
  green;
  background-color: transparent;
  text-decoration: none;
}
a:visited
  { color:
  pink;
background-color: transparent;
  text-decoration: none;
}
a:hover
  { color:
  red;
background-color: transparent;
  text-decoration: underline;
}
a:active
  { color:
  yellow;
background-
  color:
  transparent;
text-decoration:
  underline;
}
</style>
Example
Link
Buttons                                                                        32
a:hover, a:active
  { background-color:
  red;
}
</style>
HTML Links –
Create
Bookmarks
HTML links can be used to create bookmarks, so that readers can jump
to specific parts of a web page.
To create a bookmark - first create the bookmark, then add a link to it.
When the link is clicked, the page will scroll down or up to the location
with the bookmark.
Example
First, use the id attribute to create a bookmark:
Example
<h2 id="C4">Chapter 4</h2>
<a href="#C4">Jump
Then,                 to bookmark
      add a link to the   Chapter 4</a>
                                   ("Jump to Chapter 4"), from within the
same page:
                                                                            33
You can also add a link to a bookmark on another page:
Section Summary
      Use the id attribute (id="value") to define bookmarks in a page
      Use the href attribute (href="#value") to link to the bookmark
HTML Images
Images can improve the design and the appearance of 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.
Syntax
<img src="url" alt="alternatetext">
                                                                           34
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.
Example
<img src="img_chania.jpg" alt="Flowers in Chania">
Example
<img src="img_girl.jpg" alt="Girl in a
jacket" style="width:500px;height:600px;">
Example
<img src="img_girl.jpg" alt="Girl in a
jacket" width="500" height="600">
The width and height attributes always define the width and height of
the image in pixels.
                                                                             35
Note: Always specify the width and height of an image.
Example
<!DOCTYPE html>
<html>
<head>
<style>
img {
   width
   :
   100%;
}
</
style>
</head>
<body>
<img
src="ht
ml5.gif
"
alt="HT
ML5
Icon"
width="
128"
height=
"128">
Example
<img
<img  src="programming.gif" alt="Computer
src="ht
ml5.gif
Man"  style="width:48px;height:48px;">
"
Image as a Link
alt="HT
ML5
Icon"
style="
To use an image as a link, put the <img> tag
width:1
inside the <a> tag:
28px;he
Example
ight:12
8px;">
<a href="default.asp">
  <img src="smiley.gif" alt="HTML
</body>
</html>
                                                         36
Ani
mat
tutorial" style="width:42px;height:42px;">
</a>
Section Summary
      Use the HTML <img> element to define an image
      Use the HTML src attribute to define the URL of the
       image
                                                                         37
     Use the HTML alt attribute to define an alternate text for an
      image, if it cannot be displayed
     Use the HTML width and height attributes or the
      CSS width and height properties to define the size of the image
Note: Loading large images takes time, and can slow down your web
page. Use images carefully.
                                                                        38
Part II
HTML Tables
HTML tables allow web developers to arrange data into rows and
columns.
Example
Company                                       Contact                  Country
Each table row is defined with a <tr> tag. Each table header is
defined with a <th> tag. Each table data/cell is defined with a <td>
tag.
                                                                         39
Example
A simple HTML table:
<table style="width:100%">
  <tr>
    <th>Firstname</th>
    <th>Lastname</th>
    <th>Age</th>
  </tr>
  <tr>
    <td>Jill</td>
    <td>Smith</td>
    <td>50</td>
  </tr>
  <tr>
    <td>Eve</td>
    <td>Jackson</td>
    <td>94</td>
  </tr>
</table>
Note: The <td> elements are the data containers of the table.
They can contain all sorts of HTML elements; text, images, lists, other
tables, etc.
Example
table, th, td {
  border: 1px solid black;
}
Remember to define borders for both the table and the table cells.
                                                                          40
To left-align the table headings, use the CSS text-align property:
Example
th {
  text-align: left;
}
                                                                     41
  </tr>
  <tr>
    <th rowspan="2">Telephone:</th>
    <td>55577854</td>
  </tr>
  <tr>
    <td>55577855</td>
  </tr>
</table>
Example
<table style="width:100%">
  <caption>Monthly savings</caption>
  <tr>
    <th>Month</th>
    <th>Savings</th>
  </tr>
  <tr>
    <td>January</td>
    <td>$100</td>
  </tr>
  <tr>
    <td>February</td>
    <td>$50</td>
  </tr>
</table>
                                                                             42
  Example
  <table id="t01">
    <tr>
      <th>Firstname</th>
      <th>Lastname</th>
      <th>Age</th>
    </tr>
    <tr>
      <td>Eve</td>
      <td>Jackson</td>
      <td>94</td>
    </tr>
  </table>
  Section Summary
        Use the HTML <table> element to define a table
        Use the HTML <tr> element to define a table row
        Use the HTML <td> element to define a table data
        Use the HTML <th> element to define a table heading
        Use the HTML <caption> element to define a table caption
        Use the CSS border property to define a border
        Use the CSS text-align property to align cell text
        Use the colspan attribute to make a cell span many
         columns
        Use the rowspan attribute to make a cell span many rows
        Use the id attribute to uniquely define one table
Exercise:
Add a table row with two table headers.
The two table headers should have the value "Name" and "Age".
                                                                    43
<table>
  <tr>
    <td>Jill Smith</td>
    <td>50</td>
  </tr>
</table>
  HTML Lists
  HTML lists allow web developers to group a set of related items in lists.
  Example
  An unordered HTML list:
         Item
         Item
         Item
         Item
     1.   First item
     2.   Second item
     3.   Third item
     4.   Fourth item
  The list items will be marked with bullets (small black circles) by
  default:
                                                                         44
Example
<ul>
  <li>Coffee</li>
  <li>Tea</li>
  <li>Milk</li>
</ul>
Example
<ol>
  <li>Coffee</li>
  <li>Tea</li>
  <li>Milk</li>
</ol>
The <dl> tag defines the description list, the <dt> tag defines the
term (name), and the <dd> tag describes each term:
Example
<dl>
  <dt>Coffee</dt>
  <dd>- black hot drink</dd>
  <dt>Milk</dt>
  <dd>- white cold drink</dd>
</dl>
                                                                          45
HTML List Tags
Tag            Description
The list items will be marked with bullets (small black circles) by
default:
                                                                      46
Example
<ul>
  <li>Coffee</li>
  <li>Tea</li>
  <li>Milk</li>
</ul>
Value Description
Example - Disc
<ul style="list-style-type:disc;">
  <li>Coffee</li>
  <li>Tea</li>
  <li>Milk</li>
</ul>
                                                                           47
Example - Circle
<ul style="list-style-type:circle;">
  <li>Coffee</li>
  <li>Tea</li>
  <li>Milk</li>
</ul>
Example - Square
<ul style="list-style-type:square;">
  <li>Coffee</li>
  <li>Tea</li>
  <li>Milk</li>
</ul>
Example - None
<ul style="list-style-type:none;">
  <li>Coffee</li>
  <li>Tea</li>
  <li>Milk</li>
</ul>
Example
<ul>
  <li>Coffee</li>
  <li>Tea
     <ul>
       <li>Black tea</li>
       <li>Green tea</li>
     </ul>
  </li>
  <li>Milk</li>
</ul>
                                          48
Note: A list item (<li>) can contain a new list, and other HTML elements,
like images and links, etc.
Section Summary
      Use the HTML <ul> element to define an unordered list
      Use the CSS list-style-type property to define the list item
       marker
      Use the HTML <li> element to define a list item
      Lists can be nested
      List items can contain other HTML elements
Example
<ol>
  <li>Coffee</li>
  <li>Tea</li>
  <li>Milk</li>
</ol>
                                                                        49
Type       Description
type="I" The list items will be numbered with uppercase roman numbers
type="i" The list items will be numbered with lowercase roman numbers
Numbers:
<ol type="1">
  <li>Coffee</li>
  <li>Tea</li>
  <li>Milk</li>
</ol>
Uppercase Letters:
<ol type="A">
  <li>Coffee</li>
  <li>Tea</li>
  <li>Milk</li>
</ol>
                                                                    50
Lowercase Letters:
<ol type="a">
  <li>Coffee</li>
  <li>Tea</li>
  <li>Milk</li>
</ol>
Example
<ol start="50">
  <li>Coffee</li>
  <li>Tea</li>
  <li>Milk</li>
</ol>
                                                                           51
Example
<ol>
  <li>Coffee</li>
  <li>Tea
     <ol>
       <li>Black tea</li>
       <li>Green tea</li>
     </ol>
  </li>
  <li>Milk</li>
</ol>
Note: A list item (<li>) can contain a new list, and other HTML elements,
like images and links, etc.
Section Summary
      Use the HTML <ol> element to define an ordered list
      Use the HTML type attribute to define the numbering type
      Use the HTML <li> element to define a list item
      Lists can be nested
      List items can contain other HTML elements
The <dl> tag defines the description list, the <dt> tag defines the
term (name), and the <dd> tag describes each term:
Example
<dl>
  <dt>Coffee</dt>
                                                                          52
  <dd>- black hot drink</dd>
  <dt>Milk</dt>
  <dd>- white cold drink</dd>
</dl>
Section Summary
      Use the HTML <dl> element to define a description list
      Use the HTML <dt> element to define the description term
      Use the HTML <dd> element to describe the term in a
       description list
Block-level Elements
A block-level element always starts on a new line.
Example
<div>Hello World</div>
                                                                            53
<h1>-<h6>, <header>, <hr>, <li>, <main>, <nav>, <noscript>, <ol>
,
<p>, <pre>, <section>, <table>, <tfoot>, <ul>, <video>
Inline Elements
An inline element does not start on a new line.
Example
<span>Hello World</span>
The <div> element has no required attributes, but style, class and id
are common.
When used together with CSS, the <div> element can be used to
style blocks of content:
Example
<div style="background-color:black;color:white;padding:20px;">
  <h2>London</h2>
  <p>London is the capital city of England. It is the most
populous city in the United Kingdom, with a metropolitan area of
over 13
                                                                        54
million inhabitants.</p>
</div>
The <span> element has no required attributes, but style, class and id
are common.
When used together with CSS, the <span> element can be used to
style parts of the text:
Example
<p>My mother has <span style="color:blue;font-
weight:bold">blue</span> eyes and my father
has <span style="color:darkolivegreen;font-weight:bold">dark
green</span> eyes.</p>
Section Summary
      There are two display values: block and inline
      A block-level element always starts on a new line and takes up the
       full width available
      An inline element does not start on a new line and it only takes up
       as much width as necessary
      The <div> element is a block-level and is often used as a
       container for other HTML elements
      The <span> element is an inline container used to mark up a part
       of
       a text, or a part of a document
                                                                         55
Using The class Attribute
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.
Example
<!DOCTYPE html>
<html>
<head>
<style>
.city {
  background-color: tomato;
  color: white;
  border: 2px solid black;
  margin: 20px;
  padding: 20px;
}
</style>
</head>
<body>
<div
class="city">
  <h2>London</
  h2>
  <p>London is
  the capital of
  England.</p>
</div>
<div class="city">
  <h2>Paris</h2>
 <p>Paris is the
    capital of
    France.</p>
</div>
                                                                              56
<div class="city">
  <h2>Tokyo</h2>
  <p>Tokyo is the capital of Japan.</p>
</div>
</body>
</html>
<h1>My <span
class="note">Impor
tant</span>
Heading</h1>
<p>This is some
<span
class="note">impor
Tip: The class attribute can be used on any HTML element.
tant</span>
text.</p>
Note:  The class name is case sensitive!
Example
Create a class named "city":
                                                                             57
  <!DOCTYPE html>
  <html>
  <head>
  <style>
  .city {
    background-color: tomato;
    color: white;
    padding: 10px;
  }
  </style>
  </head>
  <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>
  </body>
  </html>
  Section
  Summary
        The HTML class attribute specifies one or more class names for
         an element
        Classes are used by CSS and JavaScript to select and access
         specific elements
        The class attribute can be used on any HTML element
        The class name is case sensitive
        Different HTML elements can point to the same class name
    Exercise:
                                                                          58
Create a class selector named "special".
Add a color property with the value "blue" inside the "special" class.
<!DOCTYPE html>
<html>
<head>
<style>
</style>
</head>
<body>
</body>
</html>
  HTML id Attribute
  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.
                                                                            59
In the following example we have an <h1> element that points to the
id name "myHeader". This <h1> element will be styled according to
the #myHeader style definition in the head section:
Example
<!DOCTYPE html>
<html>
<head>
<style>
#myHeader {
  background-color: lightblue;
  color: black;
  padding: 40px;
  text-align: center;
}
</style>
</head>
<body>
<h1 id="myHeader">My
Header</h1>
</body>
</html>
Note: The id name is case sensitive!
Note: The id name must contain at least one character, and must not
contain whitespaces (spaces, tabs, etc.).
Section Summary
      The id attribute is used to specify a unique id for an HTML
       element
      The value of the id attribute must be unique within the
       HTML document
      The id attribute is used by CSS and JavaScript to
       style/select a
       specific element
      The value of the id attribute is case sensitive
                                                                      60
HTML Iframes
An HTML iframe is used to display a web page within a web page.
Syntax
<iframe src="url" title="description">
Example
<iframe src="demo_iframe.htm" height="200" width="300" title="Iframe
Example"></iframe>
Example
<iframe src="demo_iframe.htm" style="height:200px;width:300px;" titl
e="Iframe Example"></iframe>
                                                                        61
Iframe - Remove the Border
By default, an iframe has a border around it.
To remove the border, add the style attribute and use the
CSS border property:
Example
<iframe src="demo_iframe.htm" style="border:none;" title="Iframe
Example"></iframe>
With CSS, you can also change the size, style and color of the iframe's
border:
Example
<iframe src="demo_iframe.htm" style="border:2px solid
red;" title="Iframe Example"></iframe>
The target attribute of the link must refer to the name attribute of
the iframe:
Example
<iframe src="demo_iframe.htm" name="iframe_a" title="Iframe
Example"></iframe>
                                                                          62
Section Summary
    The HTML <iframe> tag specifies an inline frame
    The src attribute defines the URL of the page to embed
    Always include a title attribute (for screen readers)
    The height and width attributes specifies the size of the
     iframe
    Use border:none; to remove the border around the iframe
                                                                 63
Part III
HTML Forms
An HTML form is used to collect user input. The user input is most
often sent to a server for processing.
Example
First name:
 John
Last name:
 Doe
Submit
<form>
form elements
</form>
                                                                     64
Type                        Description
Text Fields
The <input type="text"> defines a single-line input field for text input.
Example
A form with input fields for text:
<form>
  <label   for="fname">First name:</label><br>
  <input   type="text" id="fname" name="fname"><br>
  <label   for="lname">Last name:</label><br>
  <input   type="text" id="lname" name="lname">
</form>
Last name:
Note: The form itself is not visible. Also note that the default width of
an input field is 20 characters.
elements.
The <label> element is useful for screen-reader users, because the screen-
reader will read out loud the label when the user focuses on the input
element.
The <label> element also help users who have difficulty clicking on very
small regions (such as radio buttons or checkboxes) - because when the
user clicks the text within the <label> element, it toggles the radio
button/checkbox.
The for attribute of the <label> tag should be equal to the id attribute
of the <input> element to bind them together.
Radio Buttons
The <input type="radio"> defines a radio button.
<form>
  <input    type="radio" id="male" name="gender" value="male">
  <label    for="male">Male</label><br>
  <input    type="radio" id="female" name="gender" value="female">
  <label    for="female">Female</label><br>
                                                                            66
  <input type="radio" id="other" name="gender" value="other">
  <label for="other">Other</label>
</form>
Male
Female
Other
Chec
kbox
es
The
Example
<input
type="chec
kbox">
A  form with
defines  a    checkboxes:
checkbo
<form>
x.
   <input type="checkbox" id="vehicle1" name="vehicle1" value="Bike">
Checkboxes    let a user select
   <label for="vehicle1">     I ZERO
                                have aorbike</label><br>
                                         MORE options of a limited number
of <input
    choices.type="checkbox" id="vehicle2" name="vehicle2" value="Car">
   <label for="vehicle2"> I have a car</label><br>
   <input type="checkbox" id="vehicle3" name="vehicle3" value="Boat">
   <label for="vehicle3"> I have a boat</label>
</form>
I have a bike
I have a car
      I have a
      boat
                                                                       67
The Submit Button
The <input type="submit"> defines a button for submitting the form data
to a form-handler.
Example
A form with a submit button:
<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>
First name:
 John
Last name:
 Doe
Submit
If the name attribute is omitted, the value of the input field will not be
sent at all.
Example
                                                                             68
This example will not submit the value of the "First name" input field:
<form action="/action_page.php">
  <label for="fname">First name:</label><br>
  <input type="text" id="fname" value="John"><br><br>
  <input type="submit" value="Submit">
</form>
Usually, the form data is sent to a file on the server when the user clicks
on the submit button.
Example
On submit, send form data to "action_page.php":
<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>
                                                                          69
The Target Attribute
The target attribute specifies where to display the response that
is received after submitting the form.
Value Description
The default value is _self which means that the response will open in
the current window.
Example
Here, the submitted result will open in a new browser tab:
                                                                        70
The Method Attribute
The method attribute specifies the HTTP method to be used
when submitting the form data.
Example
This example uses the GET method when submitting the form data:
Example
This example uses the POST method when submitting the form data:
Notes on GET:
Notes on POST:
      Appends the form data inside the body of the HTTP request (the
       submitted form data is not shown in the URL)
      POST has no size limitations, and can be used to send large
       amounts of data.
      Form submissions with POST cannot be bookmarked
Tip: Always use POST if the form data contains sensitive or personal
information!
                                                                        71
The Autocomplete Attribute
The autocomplete attribute specifies whether a form should have
autocomplete on or off.
Example
A form with autocomplete on:
Example
A form with a novalidate attribute:
                                                                          72
action         Specifies where to send the form-data when a form is submitted
enctype        Specifies how the form-data should be encoded when submitting it to the server (only for
               method="post")
novalidate Specifies that the form should not be validated when submitted
rel Specifies the relationship between a linked resource and the current document
target Specifies where to display the response that is received after submitting the form
                                                                                            73
      <input>
      <label>
      <select>
      <textarea>
      <button>
      <fieldset>
      <legend>
      <datalist>
      <output>
      <option>
      <optgroup>
Example
<label for="fname">First name:</label>
<input type="text" id="fname" name="fname">
The <label> element is useful for screen-reader users, because the screen-
reader will read out loud the label when the user focus on the input
element.
The <label> element also help users who have difficulty clicking on very
small regions (such as radio buttons or checkboxes) - because when the
user clicks the text within the <label> element, it toggles the radio
button/checkbox.
The for attribute of the <label> tag should be equal to the id attribute
of the <input> element to bind them together.
                                                                           74
The <select> Element
The <select> element defines a drop-down list:
Example
<label for="cars">Choose a car:</label>
<select id="cars" name="cars">
  <option value="volvo">Volvo</option>
  <option value="saab">Saab</option>
  <option value="fiat">Fiat</option>
  <option value="audi">Audi</option>
</select>
Visible Values:
Use the size attribute to specify the number of visible
values:
Example
<label for="cars">Choose a car:</label>
<select id="cars" name="cars" size="3">
  <option value="volvo">Volvo</option>
  <option value="saab">Saab</option>
  <option value="fiat">Fiat</option>
  <option value="audi">Audi</option>
</select>
                                                                         75
Example
<label for="cars">Choose a car:</label>
<select id="cars" name="cars" size="4" multiple>
  <option value="volvo">Volvo</option>
  <option value="saab">Saab</option>
  <option value="fiat">Fiat</option>
  <option value="audi">Audi</option>
</select>
Example
<textarea name="message" rows="10" cols="30">
The cat was playing in the garden.
</textarea>
area. The cols attribute specifies the visible width of a text area.
You can also define the size of the text area by using CSS:
Example
<textarea name="message" style="width:200px; height:600px;">
The cat was playing in the garden.
</textarea>
                                                                         76
The <button> Element
The <button> element defines a clickable button:
Example
<button type="button" onclick="alert('Hello World!')">Click
Me!</button>
Note: Always specify the type attribute for the button element.
Different browsers may use different default types for the button
element.
element.
Example
<form action="/action_page.php">
  <fieldset>
    <legend>Personalia:</legend>
    <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">
  </fieldset>
</form>
Personalia:First name:
 John
Last name:
 Doe
Submit
                                                                    77
The <datalist> Element
The <datalist> element specifies a list of pre-defined options for
an <input> element.
Users will see a drop-down list of the pre-defined options as they input
data.
The list attribute of the <input> element, must refer to the id attribute
of the <datalist> element.
Example
<form action="/action_page.php">
  <input list="browsers">
  <datalist id="browsers">
    <option value="Internet Explorer">
    <option value="Firefox">
    <option value="Chrome">
    <option value="Opera">
    <option value="Safari">
  </datalist>
</form>
Example
Perform a calculation and show the result in an <output> element:
<form action="/action_page.php"
  oninput="x.value=parseInt(a.value)+parseInt(b.value)">
  0
<input type="range"      id="a" name="a" value="50">
100 +
<input type="number" id="b" name="b" value="50">
=
<output name="x" for="a b"></output>
                                                                            78
  <br><br>
  <input type="submit">
</form>
     <input type="button">
     <input type="checkbox">
     <input type="color">
     <input type="date">
     <input type="datetime-local">
     <input type="email">
     <input type="file">
     <input type="hidden">
     <input type="image">
     <input type="month">
     <input type="number">
     <input type="password">
     <input type="radio">
     <input type="range">
     <input type="reset">
     <input type="search">
     <input type="submit">
     <input type="tel">
     <input type="text">
     <input type="time">
     <input type="url">
     <input type="week">
Tip: The default value of the type attribute is "text".
                                                              79
Example
<form>
  <label   for="fname">First name:</label><br>
  <input   type="text" id="fname" name="fname"><br>
  <label   for="lname">Last name:</label><br>
  <input   type="text" id="lname" name="lname">
</form>
First name:
Last name:
Example
<form>
  <label   for="username">Username:</label><br>
  <input   type="text" id="username" name="username"><br>
  <label   for="pwd">Password:</label><br>
  <input   type="password" id="pwd" name="pwd">
</form>
Username:
Password:
                                                                       80
Input Type Submit
<input type="submit"> defines a button for submitting form data to
a form-handler.
Example
<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>
First name:
 John
Last name:
 Doe
Submit
If you omit the submit button's value attribute, the button will get a
default text:
Example
<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>
                                                                           81
  <input type="submit">
</form>
Example
<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">
  <input type="reset">
</form>
First name:
 John
Last name:
 Doe
Submit Reset
If you change the input values and then click the "Reset" button, the
form-data will be reset to the default values.
Radio buttons let a user select ONLY ONE of a limited number of choices:
Example
                                                                         82
<form>
  <input     type="radio" id="male" name="gender" value="male">
  <label     for="male">Male</label><br>
  <input     type="radio" id="female" name="gender" value="female">
  <label     for="female">Female</label><br>
  <input     type="radio" id="other" name="gender" value="other">
  <label     for="other">Other</label>
</form>
Male
Female
Other
Input
Type
Chec
kbox
Example
<input
type="chec
<form>
kbox">
   <inputa type="checkbox" id="vehicle1" name="vehicle1" value="Bike">
defines
   <label for="vehicle1"> I have a bike</label><br>
checkbo
x. <input type="checkbox" id="vehicle2" name="vehicle2" value="Car">
   <label for="vehicle2"> I have a car</label><br>
Checkboxes   let a user select
   <input type="checkbox"      ZERO or MORE
                             id="vehicle3"   options of a limited
                                           name="vehicle3"        number
                                                             value="Boat">
of <label
   choices.for="vehicle3"> I have a boat</label>
</form>
I have a bike
I have a car
    I have a
    boat
                                                                       83
Input Type Button
<input type="button"> defines a button:
Example
<input type="button" onclick="alert('Hello World!')" value="Click
Me!">
You can also use the min and max attributes to add restrictions to
dates:
                                                                          84
Example
<form>
  <label for="datemax">Enter a date before 1980-01-01:</label>
  <input type="date" id="datemax" name="datemax" max="1979-12-
31"><br><br>
    <label for="datemin">Enter a date after
  2000-01-01:</label>
    <input type="date" id="datemin" name="datemin" min="2000-
  01-02">
  </form>
Some smartphones recognize the email type, and add ".com" to the
keyboard to match email input.
Example
<form>
  <label for="email">Enter your email:</label>
                                                                             85
  <input type="email" id="email" name="email">
</form>
Example
<form>
  <label for="myfile">Select a file:</label>
  <input type="file" id="myfile" name="myfile">
</form>
Example
<form>
  <label for="bdaymonth">Birthday (month and year):</label>
  <input type="month" id="bdaymonth" name="bdaymonth">
</form>
The following example displays a numeric input field, where you can enter
a value from 1 to 5:
Example
                                                                          86
<form>
  <label for="quantity">Quantity (between 1 and 5):</label>
  <input type="number" id="quantity" name="quantity" min="1"
  max="5"
>
</form>
Input Restrictions
Here is a list of some common input restrictions:
Attribute Description
                                                                        87
readonly              Specifies that an input field is read only (cannot be changed)
The following example displays a numeric input field, where you can enter
a value from 0 to 100, in steps of 10. The default value is 30:
Example
<form>
  <label for="quantity">Quantity:</label>
  <input type="number" id="quantity" name="quantity" min="0"
max="10 0" step="10" value="30">
  </form>
                                                                            88
  <input type="range" id="vol" name="vol" min="0"
  max="50">
</form>
Example
<form>
  <label for="gsearch">Search Google:</label>
  <input type="search" id="gsearch" name="gsearch">
</form>
Example
<form>
  <label for="phone">Enter your phone number:</label>
  <input type="tel" id="phone" name="phone" pattern="[0-9]{3}-[0-
9]{2}-[0-9]{3}">
  </form>
                                                                          89
  <input type="time" id="appt" name="appt">
</form>
Some smartphones recognize the url type, and adds ".com" to the
keyboard to match url input.
Example
<form>
  <label for="homepage">Add your homepage:</label>
  <input type="url" id="homepage" name="homepage">
</form>
Example
<form>
  <label for="week">Select a week:</label>
  <input type="week" id="week" name="week">
</form>
                                                                        90
The value Attribute
The input value attribute specifies an initial value for an input
field:
Example
Input fields with initial (default) values:
<form>
  <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">
</form>
A read-only input field cannot be modified (however, a user can tab to it,
highlight it, and copy the text from it).
The value of a read-only input field will be sent when submitting the
form!
Example
A read-only input field:
<form>
  <label for="fname">First name:</label><br>
  <input type="text" id="fname" name="fname" value="John"
readonly>< br>
    <label for="lname">Last name:</label><br>
    <input type="text" id="lname" name="lname" value="Doe">
  </form>
                                                                           91
A disabled input field is unusable and un-clickable.
The value of a disabled input field will not be sent when submitting the
form!
Example
A disabled input field:
<form>
  <label for="fname">First name:</label><br>
  <input type="text" id="fname" name="fname" value="John"
disabled>< br>
    <label for="lname">Last name:</label><br>
    <input type="text" id="lname" name="lname" value="Doe">
  </form>
  Note: The size attribute works with the following input types:
text, search, tel, url, email, and password.
Example
Set a width for an input field:
<form>
  <label   for="fname">First name:</label><br>
  <input   type="text" id="fname" name="fname" size="50"><br>
  <label   for="pin">PIN:</label><br>
  <input   type="text" id="pin" name="pin" size="4">
</form>
                                                                            92
The maxlength Attribute
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.
Example
Set a maximum length for an input field:
<form>
  <label   for="fname">First name:</label><br>
  <input   type="text" id="fname" name="fname" size="50"><br>
  <label   for="pin">PIN:</label><br>
  <input   type="text" id="pin" name="pin" maxlength="4" size="4">
</form>
The min and max attributes work with the following input types:
number, range, date, datetime-local, month, time and week.
Tip: Use the max and min attributes together to create a range of legal
values.
Example
Set a max date, a min date, and a range of legal values:
<form>
  <label for="datemax">Enter a date before 1980-01-01:</label>
  <input type="date" id="datemax" name="datemax" max="1979-12-
31"><br><br>
                                                                           93
  <label for="datemin">Enter a date after 2000-01-01:</label>
  <input type="date" id="datemin" name="datemin" min="2000-01-
02"><br><br>
  The multiple attribute works with the following input types: email,
and file.
Example
A file upload field that accepts multiple values:
<form>
  <label for="files">Select files:</label>
  <input type="file" id="files" name="files" multiple>
</form>
The pattern attribute works with the following input types: text,
date, search, url, tel, email, and password.
Tip: Use the global title attribute to describe the pattern to help the
user.
                                                                          94
An input field that can contain only three letters (no numbers or
special characters):
<form>
  <label for="country_code">Country code:</label>
  <input type="text" id="country_code" name="country_code"
  pattern="[A-Za-z]{3}" title="Three letter country code">
</form>
The short hint is displayed in the input field before the user enters a
value.
Example
An input field with a placeholder text:
<form>
  <label for="phone">Enter a phone number:</label>
  <input type="tel" id="phone" name="phone"
  placeholder="123-45-678"
  pattern="[0-9]{3}-[0-9]{2}-[0-9]{3}">
</form>
The required attribute works with the following input types: text, search,
url, tel, email, password, date pickers, number, checkbox, radio, and file.
Example
                                                                            95
A required input field:
<form>
  <label for="username">Username:</label>
  <input type="text" id="username" name="username" required>
</form>
Tip: This attribute can be used together with the max and min attributes
to create a range of legal values.
The step attribute works with the following input types: number, range,
date, datetime-local, month, time and week.
Example
An input field with a specified legal number intervals:
<form>
  <label for="points">Points:</label>
  <input type="number" id="points" name="points"
  step="3">
</form>
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)!
Example
Let the "First name" input field automatically get focus when the page
loads:
                                                                          96
<form>
  <label   for="fname">First name:</label><br>
  <input   type="text" id="fname" name="fname" autofocus><br>
  <label   for="lname">Last name:</label><br>
  <input   type="text" id="lname" name="lname">
</form>
Example
Define an image as the submit button, with height and width attributes:
<form>
  <label for="fname">First name:</label>
  <input type="text" id="fname" name="fname"><br><br>
  <label for="lname">Last name:</label>
  <input type="text" id="lname" name="lname"><br><br>
  <input type="image" src="img_submit.gif" alt="Submit" width="48" h
eight="48">
  </form>
Example
An <input> element with pre-defined values in a <datalist>:
<form>
  <input list="browsers">
  <datalist id="browsers">
    <option value="Internet Explorer">
    <option value="Firefox">
    <option value="Chrome">
    <option value="Opera">
                                                                          97
    <option value="Safari">
  </datalist>
</form>
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.
Example
An HTML form with autocomplete on, and off for one input field:
                                                                         98
The form Attribute
The input form attribute specifies the form the <input> element belongs to.
Example
An input field located outside of the HTML form (but still a part of the
form):
Note: This attribute overrides the action attribute of the <form> element.
The formaction attribute works with the following input types: submit
and image.
Example
An HTML form with two submit buttons, with different actions:
<form action="/action_page.php">
  <label for="fname">First name:</label>
  <input type="text" id="fname" name="fname"><br><br>
  <label for="lname">Last name:</label>
  <input type="text" id="lname" name="lname"><br><br>
  <input type="submit" value="Submit">
                                                                           99
  <input type="submit" formaction="/action_page2.php" value="Submit
as Admin">
  </form>
  The formenctype attribute works with the following input types: submit
and image.
Example
A form with two submit buttons. The first sends the form-data with
default encoding, the second sends the form-data encoded as
"multipart/form-data":
The formmethod attribute works with the following input types: submit
and image.
Note: This attribute overrides the target attribute of the <form> element.
The formtarget attribute works with the following input types: submit
and image.
Example
                                                                         101
A form with two submit buttons, with different target windows:
<form action="/action_page.php">
  <label for="fname">First name:</label>
  <input type="text" id="fname" name="fname"><br><br>
  <label for="lname">Last name:</label>
  <input type="text" id="lname" name="lname"><br><br>
  <input type="submit" value="Submit">
  <input type="submit" formtarget="_blank" value="Submit to a new
window/tab">
  </form>
<form action="/action_page.php">
  <label for="email">Enter your email:</label>
  <input type="email" id="email" name="email"><br><br>
  <input type="submit" value="Submit">
  <input type="submit" formnovalidate="formnovalidate"
  value="Submit without validation">
</form>
When present, novalidate specifies that all of the form-data should not be
validated when submitted.
                                                                       102
  Example
                                        103
           Introduction to CSS
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)!
          Using CSS
          CSS can be added to HTML documents in 3 ways:
          The most common way to add CSS is to keep the styles in external CSS
          files.
                                                                                      104
Inline CSS
An inline CSS is used to apply a unique style to a single HTML element.
The following example sets the text color of the <h1> element to blue,
and the text color of the <p> element to red:
Example
<h1 style="color:blue;">A Blue Heading</h1>
Internal CSS
An internal CSS is used to define a style for a single HTML page.
The following example sets the text color of ALL the <h1> elements (on
that page) to blue, and the text color of ALL the <p> elements to red.
In addition, the page will be displayed with a "powderblue" background
color:
Example
<!DOCTYPE html>
<html>
<head>
<style>
body {background-color: powderblue;}
h1   {color: blue;}
p    {color: red;}
</style>
</head>
<body>
<h1>This is a heading</h1>
<p>This is a paragraph.</p>
                                                                          105
</body>
</html>
External CSS
An external style sheet is used to define the style for many HTML pages.
Example
<!DOCTYPE html>
<html>
<head>
  <link rel="stylesheet" href="styles.css">
</head>
<body>
<h1>This is a heading</h1>
<p>This is a paragraph.</p>
</body>
</html>
The external style sheet can be written in any text editor. The file must
not contain any HTML code, and must be saved with a .css extension.
"styles.css":
body {
  background-color: powderblue;
}
h1 {
  color: blue;
}
p {
  color: red;
}
Tip: With an external style sheet, you can change the look of an entire
web site, by changing one file!
                                                                            106
CSS Colors, Fonts and Sizes
Here, we will demonstrate some commonly used CSS properties.
Example
Use of CSS color, font-family and font-size properties:
<!DOCTYPE html>
<html>
<head>
<style>
h1 {
  color
  :
  blue;
  font-family: verdana;
  font-size: 300%;
}
p {
  color: red;
  font-family: courier;
  font-size: 160%;
}
</style>
</head>
<body>
<h1>This is a
heading</h1>
<p>This is a
paragraph.</p>
</body>
</html>
CSS Border
The CSS border
property defines a                                             107
border around an HTML
element.
Example
Use of CSS border property:
p {
  border: 2px solid powderblue;
}
CSS Padding
The CSS padding property defines a padding (space) between the
text and the border.
Example
Use of CSS border and padding properties:
p {
  border: 2px solid powderblue;
  padding: 30px;
}
CSS Margin
The CSS margin property defines
a margin (space) outside the
border.
Example
Use of CSS border and margin properties:
p {
  border: 2px solid powderblue;
  margin: 50px;
}
Link to External
CSS
External style sheets can be referenced with a full URL or with a
path relative to the current web page.
                                                                    108
  Example
  This example uses a full URL to link to a style sheet:
  Example
  This example links to a style sheet located in the html folder on the
  current web site:
  Section Summary
        Use the HTML style attribute for inline styling
        Use the HTML <style> element to define internal CSS
        Use the HTML <link> element to refer to an external CSS
         file
        Use the HTML <head> element to store <style> and
         <link> elements
        Use the CSS color property for text colors
        Use the CSS font-family property for text fonts
        Use the CSS font-size property for text sizes
        Use the CSS border property for borders
        Use the CSS padding property for space inside the border
        Use the CSS margin property for space outside the border
Exercise:
Use CSS to set the background color of the document (body) to yellow.
<!DOCTYPE html>
<html>
<head>
<style>
                                                                          109
 Introduction to 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.
This JavaScript example writes "Hello JavaScript!" into an HTML element with
id="demo":
      Example
 <script>
 document.getElementById("demo").innerHTML = "Hello JavaScript!";
 </script>
 A Taste of JavaScript
 Here are some examples of what JavaScript can do:
      Example
      JavaScript can change content:
                                                                               110
Example
JavaScript can change styles:
document.getElementById("demo").style.fontSize = "25px";
document.getElementById("demo").style.color = "red";
document.getElementById("demo").style.backgroundColor = "yellow";
Example
JavaScript can change attributes:
document.getElementById("image").src = "picture.gif";
Example
<script>
document.getElementById("demo").innerHTML = "Hello JavaScript!";
</script>
<noscript>Sorry, your browser does not
support JavaScript!</noscript>
111