HTML and CSS Grade 8 Booklet
HTML and CSS Grade 8 Booklet
Summary: HTML
2
I     ntroduction to HTML
In this module, you'll dive into the world of HTML (HyperText Markup Language), the
fundamental building block of web pages.
What is HTML?
HTML is a markup language used to create and design web pages. It’s like the skeleton
of a webpage, giving it structure and meaning. Think of HTML as the language that tells
your web browser how to display content, from simple text to complex images and
interactive features.
Example:
If you've ever right-clicked on a webpage and selected "View Page Source," you’ve
seen HTML code in action. This code is what browsers interpret to display the web
page.
                                                                                          3
Tools You’ll Use
To start writing HTML, you need a text editor. Unlike word processors like MS Word,
which add extra formatting codes, text editors are designed to handle plain text.
We’ll be using Notepad++ in our lessons, but other text editors like Visual Studio
Code, Atom, or Sublime Text are also great choices.
Fun Fact!
Did you know that HTML has been around since 1991? It’s been the backbone of the
web for over three decades!
Instructions:
1. Read the Descriptions: Review the descriptions of various text editors.
   -   Setup: Copy the given HTML code into a file named index.html and open it in a
       web browser.
   -   Drag-and-Drop: Learners drag text editor names into the boxes below the
       descriptions.
   -   Check Results: Ensure that each description is correctly matched with its text
       editor.
Descriptions
                                                                                      4
Code to copy
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Text Editors Comparison</title>
    <style>
        body {
            font-family: Arial, sans-serif;
            margin: 20px;
            display: flex;
            flex-direction: column;
            align-items: center;
            background-color: #f0f8ff;
        }
        .container {
            display: flex;
            justify-content: space-between;
            width: 80%;
            margin-bottom: 20px;
        }
        .box {
            width: 45%;
            padding: 20px;
            border: 1px solid #ccc;
            border-radius: 5px;
            background-color: #fff;
            min-height: 300px;
            position: relative;
        }
        .box h3 {
            margin-top: 0;
        }
        .description {
            cursor: pointer;
            padding: 10px;
            border: 1px solid #ddd;
            margin-bottom: 10px;
            border-radius: 5px;
            background-color: #fafafa;
        }
        .description.dragging {
            opacity: 0.5;
        }
        .dropzone {
            border: 2px dashed #ddd;
            height: 40px;
            line-height: 40px;
            text-align: center;
            color: #666;
            margin-bottom: 10px;
            border-radius: 5px;
        }
        .text-editor {
            cursor: pointer;
            padding: 10px;
            border: 1px solid #ddd;
            margin-bottom: 10px;
                                                                             5
            border-radius: 5px;
            background-color: #fafafa;
        }
        #check-button {
             padding: 10px 20px;
             border: none;
             border-radius: 5px;
             background-color: #28a745;
             color: white;
             font-size: 16px;
             cursor: pointer;
             margin-top: 20px;
        }
        #check-button:hover {
             background-color: #218838;
        }
        #result {
             margin-top: 10px;
             font-size: 16px;
        }
    </style>
</head>
<body>
    <h1>Match the Text Editors to Their Descriptions</h1>
    <div class="container">
        <div class="box" id="descriptions">
             <h3>Descriptions</h3>
             <div class="description" id="desc1">
                 <p>A powerful, open-source text editor with a strong
community. It supports many programming languages and has a wide range of
extensions.</p>
                 <div class="dropzone" id="drop1">Drop editor here</div>
             </div>
             <div class="description" id="desc2">
                 <p>A lightweight and fast text editor that is part of the
standard Windows installation. It lacks advanced features but is simple to
use for basic HTML coding.</p>
                 <div class="dropzone" id="drop2">Drop editor here</div>
             </div>
             <div class="description" id="desc3">
                 <p>A versatile text editor known for its speed and ease of
use. It provides a distraction-free writing experience and includes a lot
of customization options.</p>
                 <div class="dropzone" id="drop3">Drop editor here</div>
             </div>
             <div class="description" id="desc4">
                 <p>An advanced text editor with a focus on code
development. It includes features like debugging, code navigation, and Git
integration.</p>
                 <div class="dropzone" id="drop4">Drop editor here</div>
             </div>
        </div>
        <div class="box" id="editors">
             <h3>Text Editors</h3>
             <div class="text-editor" id="editor1"
draggable="true">Notepad++</div>
             <div class="text-editor" id="editor2" draggable="true">Visual
Studio Code</div>
             <div class="text-editor" id="editor3"
draggable="true">Atom</div>
             <div class="text-editor" id="editor4" draggable="true">Sublime
Text</div>
                                                                              6
         </div>
     </div>
     <button id="check-button">Check Answers</button>
     <div id="result"></div>
     <script>
         const descriptions = document.querySelectorAll('#descriptions
 .description');
         const textEditors = document.querySelectorAll('#editors .text-
 editor');
         const dropzones = document.querySelectorAll('#descriptions
 .dropzone');
           textEditors.forEach(editor => {
               editor.addEventListener('dragstart', () => {
                   editor.classList.add('dragging');
               });
               editor.addEventListener('dragend', () => {
                   editor.classList.remove('dragging');
               });
           });
           dropzones.forEach(dropzone => {
               dropzone.addEventListener('dragover', (e) => {
                   e.preventDefault();
               });
               dropzone.addEventListener('drop', (e) => {
                   e.preventDefault();
                   const draggedEditor = document.querySelector('.dragging');
                   if (draggedEditor) {
                       dropzone.textContent = draggedEditor.textContent;
                       draggedEditor.remove();
                   }
               });
           });
           document.getElementById('check-button').addEventListener('click',
 () => {
             let correct = 0;
             const correctAnswers = {
                 'drop1': 'Notepad++',
                 'drop2': 'Notepad',
                 'drop3': 'Atom',
                 'drop4': 'Sublime Text'
             };
             dropzones.forEach(dropzone => {
                 if (dropzone.textContent.trim() ===
 correctAnswers[dropzone.id]) {
                     correct++;
                 }
             });
             const total = dropzones.length;
             const resultText = `You got ${correct} out of ${total}
 correct!`;
             document.getElementById('result').textContent = resultText;
         });
     </script>
 </body>
 </html>
You do not have to study the above code for the upcoming exam.
                                                                                7
S         ummary of HTML Tags… (thus far)
1. <!DOCTYPE html>
   Purpose: Declares the document type and HTML version. It tells the web browser
   that the document is written in HTML5.
2. <html> / </html>
   Purpose: The root element that contains all other HTML elements. The opening
   <html> tag starts the HTML document, and the closing </html> tag ends it.
3. <head> / </head>
Usage: Placed inside the <html> element, before the <body> element.
4. <title> / </title>
   Purpose: Sets the title of the web page, which appears in the browser’s title bar or
   tab.
5. <body> / </body>
   Purpose: Contains the visible content of the web page, such as text, images, links,
   and other elements.
   Usage: Encloses the main content of the web page, placed inside the <html>
   element after the <head>.
6. <h1> / </h1>
   Purpose: Defines a top-level heading. <h1> is the highest level, with <h2>, <h3>,
   etc., being progressively smaller.
   Usage: Used to create headings on the web page, with <h1> being the most
   important.
                                                                                          8
7. <p> / </p>
   Purpose: Defines a paragraph of text. Automatically adds space before and after
   the paragraph.
<!DOCTYPE html>
<html>
<head>
    <title>My First Web Page</title>
</head>
<body>
    <h1>Welcome to My Web Page</h1>
    <p>This is a paragraph of text on my first web page.</p>
</body>
</html>
A ctivities
                                                                                     9
10
Find the word
                11
P         age Formatting – More Tags
1. Basic Tags
   • Headings: <h1> to <h6> represent headings of different sizes, with <h1>
     being the largest.
• Line Break: <br /> is a self-closing tag that adds a line break.
• Horizontal Line: <hr /> adds a horizontal line across the page.
   •   Bold Text:     <b> makes text bold, but an alternative is <strong>, which is more
       modern.
   •   Comments: <!-- comment --> is used for adding notes that won’t be visible on
       the webpage.
                                                                                       12
2. Attributes
   • Font Tag:       An older, deprecated tag for styling text.
3. Colors
   • Color can be defined by:
         o Names: like "red" or "blue".
o RGB: color: rgb(255, 0, 0); (where each value ranges from 0 to 255).
4. Span Tag
   1. <span> is used for styling specific parts of text within a paragraph.
5. Self-Closing Tags
   • Some tags like <br /> and <hr /> do not need a closing tag and are self-
      contained.
                                                                                      13
I        nteractive Activity: HTML Tags
Instructions:
     -   Setup: Copy the given HTML code into a file named tags.html and open it in a
         web browser.
     -   Complete the questions: Learners click on the correct answer.
 <!DOCTYPE html>
 <html lang="en">
 <head>
     <meta charset="UTF-8">
     <meta name="viewport" content="width=device-width, initial-
 scale=1.0">
     <title>HTML Tag Riddles</title>
     <style>
         body {
             font-family: Arial, sans-serif;
             background-color: #f5f5f5;
             padding: 20px;
         }
         h1 {
             color: #4CAF50;
         }
         .riddle {
             margin-bottom: 20px;
             padding: 10px;
             background-color: #fff;
             border-radius: 5px;
             box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
         }
         .options {
             margin-top: 10px;
         }
         select {
             padding: 5px;
             font-size: 16px;
         }
         .submit, .reset {
             margin-top: 20px;
             padding: 10px 20px;
             background-color: #4CAF50;
             color: #fff;
                                                                                        14
           border: none;
           border-radius: 5px;
           cursor: pointer;
        }
        .submit:hover, .reset:hover {
            background-color: #45a049;
        }
        .result {
            margin-top: 10px;
            font-weight: bold;
        }
    </style>
</head>
<body>
                                                                 15
           </select>
       </div>
   </div>
                                                                 16
            <label for="riddle5">Select the correct
tag:</label>
            <select id="riddle5">
                <option value="">--Choose an answer--</option>
                <option value="<ul>"><ul></option>
                <option value="<a>"><a></option>
                <option value="<img>"><img></option>
            </select>
        </div>
    </div>
                                                                 17
    <button class="submit" onclick="checkAnswers()">Submit
Answers</button>
    <script>
        function checkAnswers() {
            // Get selected values
            const riddle1 =
document.getElementById('riddle1').value;
            const riddle2 =
document.getElementById('riddle2').value;
            const riddle3 =
document.getElementById('riddle3').value;
            const riddle4 =
document.getElementById('riddle4').value;
            const riddle5 =
document.getElementById('riddle5').value;
            const riddle6 =
document.getElementById('riddle6').value;
            const riddle7 =
document.getElementById('riddle7').value;
           // Correct answers
           const correctAnswers = {
               riddle1: "<h1>",
               riddle2: "<p>",
               riddle3: "<br>",
               riddle4: "<hr>",
               riddle5: "<ul>",
               riddle6: "<img>",
               riddle7: "<a>"
           };
                                                                18
                     message += "         Amazing job!";
                 } else if (score         >= 4) {
                     message += "         Keep going, you're doing great!";
                 } else {
                     message += "         Don't worry, try again!";
                 }
                 document.getElementById('results').textContent =
 message;
         }
 </body>
 </html>
You do not have to study the above code for the upcoming exam.
I mages in HTML
Key Attributes
  • src (source):
      Specifies the path to your image file. Ensure the file name matches exactly
      (case-sensitive).
   •   alt (alternative):
       Provides a description for screen readers and displays if the image cannot load.
                                                                                      19
Adjusting Image Size
You can control the size of your image with the width and height attributes.
Example:
<img src="images/Earth2.png" alt="Earth image" width="320"
height="320" />
Adding Borders
You can also add a border to your image.
Example:
<img src="images/Earth2.png" alt="Earth image" width="320"
height="320" border="1" />
Centering Images
If you want your image to appear in the center of the page, wrap it in a <p> tag (or
<div> tag)
Example:
<p style="text-align: center;">
    <img src="images/myimage.png" alt="my image" />
</p>
T Ypes of Lists
                                                                                       20
Ordered Lists (OL)
• An ordered list is created using the <ol> tag.
• Like unordered lists, each item is defined with the <li> tag.
• Ordered lists are numbered automatically (1, 2, 3, etc.).
• You can change the numbering style using the type attribute. Options include:
     o type="A" for uppercase letters (A, B, C).
     o type="a" for lowercase letters (a, b, c).
     o type="I" for uppercase Roman numerals (I, II, III).
     o type="i" for lowercase Roman numerals (i, ii, iii).
Additional Features
• Both types of lists can include as many list items as needed.
• You can make list items clickable by wrapping them in an anchor (<a>) tag, allowing
  you to create a functional menu system.
A ctivity
2. Which of the following attributes is optional when using the <img> tag?
   A) src
   B) alt
   C) width
   D) height
3. What happens if you don’t include width and height attributes for an image?
   A) The image will not display
   B) The browser may take longer to load the page
   C) The image will automatically adjust its size
   D) The image will be centered on the page
True/False Questions
4. True or False: The alt attribute is used to improve accessibility for visually impaired
   users.
                                                                                         21
5. True or False: You can only use the <p> tag to center an image; the <div> tag
   cannot be used for this purpose.
6. Explain why it is important to match the file name exactly in the src attribute.
7. What is the effect of adding a border to an image using the border attribute?
Fill-in-the-Blank Questions
8. The <img> tag is a __________ tag, meaning it does not require a closing tag.
9. To center an image on the page, you can wrap it in a <p> tag and set the
   __________ property to "center."
H TML Glossary
   1. html: The root element that contains all other HTML elements in a web
      document.
   2. heading: A tag that defines a top-level heading, indicating the most important
      title on a web page.
   3. paragraph: A tag used for creating paragraphs of text, improving readability on
      web pages.
   4. src: An attribute in the img tag that specifies the path to an image file, essential
      for displaying images.
   5. browser: Software that allows users to access and view web pages on the
      internet.
   6. hr: A tag used to add a horizontal line across a web page, often used to separate
      content visually.
   7. doctype: An opening tag that declares the document type and HTML version
      being used in an HTML document.
   8. span: A tag used for styling specific parts of text within a paragraph without
      creating a new block-level element.
                                                                                        22
A
1.
                ctivities
        Scenario: Imagine you have been tasked with creating a personal webpage to
        introduce yourself to the world. This webpage will showcase your interests,
        hobbies, and some personal achievements.
                                                                                       23
2.   Build a Community Event Webpage
     Scenario: Your local community center is hosting a fun fair, and they need your
     help to create a simple webpage to promote the event. This webpage will provide
     details about the event, including the date, time, location, activities, and how to
     register.
     6. What images will you use to make the webpage visually appealing?
        Decide on images related to the event (e.g., pictures of past fairs, activities).
     Scenario: You are an aspiring travel blogger, and you want to create a
     homepage for your travel blog. This homepage will introduce visitors to your
     adventures, showcase your favorite destinations, and provide links to your travel
     stories.
                                                                                        24
4. What images will you include to make your blog visually appealing?
   Choose images from your travels that represent the destinations.
7. What links will you include to direct visitors to your travel stories?
   Think about including links to specific blog posts or categories.
                                                                                 25
P
1.
       ossible Answers
 <!DOCTYPE html>
 <html>
 <head>
     <title>Welcome to My Personal Webpage</title>
 </head>
 <body>
<h1>Welcome to My World!</h1>
<hr>
     <h2>About Me</h2>
     <p>I enjoy spending my free time exploring the outdoors,
 coding new projects, and learning about technology.</p>
     <h2>My Hobbies</h2>
     <p>Some of my hobbies include:</p>
     <ul>
         <li><span style="color: green;">Hiking</span> - I love
 discovering new trails.</li>
         <li><span style="color: blue;">Programming</span> - I
 enjoy creating websites and apps.</li>
         <li><span style="color: purple;">Photography</span> -
 Capturing beautiful moments is a passion of mine.</li>
     </ul>
<hr>
     <h2>Achievements</h2>
     <p>I recently completed a coding bootcamp and built my
 first website!</p>
 </body>
 </html>
                                                                  26
Code Explanation:
  • <!DOCTYPE html>: Declares the document type.
  • <html>, <head>, <body>: Basic structure of the HTML document.
  • <h1>: Main heading introducing the webpage.
  • <p>: Paragraphs describing the person and their interests.
  • <img>: Displays an image with a specified path and alternate text.
  • <hr>: Creates horizontal lines to separate sections.
  • <h2>: Subheadings for different sections of content.
  • <ul> and <li>: Creates an unordered list of hobbies.
  • Comments: Notes within the code that won’t appear on the webpage.
    <h2>Location</h2>
    <p>Come visit us at the Community Center Park, 123 Main
Street, Yourtown.</p>
     <h2>Activities</h2>
     <p>We have a variety of exciting activities planned:</p>
     <ul>
         <li>Games and Prizes</li>
         <li>Food Trucks</li>
         <li>Live Music Performances</li>
         <li>Arts and Crafts Booths</li>
         <li>Petting Zoo</li>
     </ul>
    <h2>Registration</h2>
    <p>To register for the event, please contact us at <a
href="mailto:info@communityfunfair.com">info@communityfunfair.c
om</a>.</p>
<h2>Gallery</h2>
                                                                         27
    <img src="images/funfair.jpg" alt="Community Fun Fair"
width="600" height="400">
<hr>
      <h2>Contact Us</h2>
      <p>If you have any questions, feel free to reach out!</p>
      <p>Phone: (123) 456-7890</p>
</body>
</html>
Code Explanation:
      <h2>Favorite Destinations</h2>
      <ul>
          <li><a href="#paris">Paris, France</a></li>
          <li><a href="#bali">Bali, Indonesia</a></li>
          <li><a href="#newyork">New York City, USA</a></li>
          <li><a href="#tokyo">Tokyo, Japan</a></li>
      </ul>
      <h2>Subscribe to My Blog</h2>
      <p>Stay updated with my latest travels by signing up!</p>
      <form action="subscribe.html" method="post">
          <label for="email">Email:</label>
          <input type="email" id="email" name="email" required>
          <input type="submit" value="Subscribe">
      </form>
     <h2>Gallery</h2>
     <img src="images/travel.jpg" alt="Travel Adventure"
 width="600" height="400">
<hr>
     <h2>About Me</h2>
     <p>Hi! I'm Jamie, a travel enthusiast who loves exploring
 new cultures and cuisines. Join me on my adventures!</p>
 </body>
 </html>
Code Explanation:
  • <!DOCTYPE html>: Declares the document type.
  • <html>, <head>, <body>: Basic structure of the HTML document.
  • <h1>: Main heading for the blog.
  • <p>: Paragraphs introducing the blog and providing personal info.
  • <ul> and <ol>: Unordered and ordered lists for destinations and latest travel
     stories.
  • <a>: Hyperlinks for destinations and blog post links.
  • <form>: Simple subscription form for email signup.
  • <img>: Displays an image related to travel.
  • <hr>: Creates a horizontal line to separate sections.
  • Comments: Notes for clarification and reminders.
                                                                                    29
H            yperlinks
Importance of Links
•   Links are essential for creating the "web" in the World Wide Web, connecting web
    pages and resources.
•   Clickable items like text or images allow users to navigate to different locations,
    such as other web pages, documents, or email addresses.
Hyperlinking Basics
    Example:
    <a href="http://example.com">Click here</a>
• You can link directly to an email address using the mailto: protocol.
    Example:
    <a href="mailto:iloveit@schoolofit.co.za">Send email</a>
This opens the user’s default email client and populates the "To:" field.
•   You can link to any type of file, such as PDFs or media files, by specifying the file's
    location.
                                                                                              30
Opening Links in a New Tab
•    By default, links open in the same tab, but you can use the target="_blank"
     attribute to open links in a new tab.
     Example:
     <a href="http://example.com" target="_blank">Open in new
     tab</a>
Clickable Images
•    Just like text, you can make images clickable by wrapping them inside an anchor
     tag.
     Example:
     <a href="http://example.com">
       <img src="image.jpg" alt="Clickable Image">
     </a>
A ctivity
1. True or False: The <a> tag is used to create clickable links on a web page.
2.      True or False: You can only use text, not images, as clickable items in a
        hyperlink.
3.      True or False: The mailto: protocol is used to create a link that opens the user’s
        default email client.
4.      True or False: Adding target="_blank" to an anchor tag will open the link in the
        same tab.
5.      True or False: You can link to a PDF document using the <a> tag, and most
        browsers will be able to open it.
                                                                                           31
I    ntroduction to Styling with CSS
CSS is a styling language used to define how HTML elements should look. It separates
the design (look and feel) from the content of a webpage.
2. Internal CSS – Adding CSS inside the <style> tag in the HTML <head>.
3. External CSS – Linking an external .css file to your HTML. This is the most
   preferred method.
Example:
<h1 style="color: green;">This is inline CSS</h1> <!-- Inline
CSS -->
<head>
    <style>
        h2 { color: blue; }            <!-- Internal CSS -->
    </style>
</head>
Here, we demonstrate how to use inline, internal, and external CSS, with external being
the most maintainable as it keeps the design separate from the content.
Colours
1. Named Colours
   Using predefined colour names like red, green, blue.
3. Hexadecimal Colours
   Using hex values like #ff0000 for red.
4. RGBA
   Same as RGB but with an additional alpha (transparency) value,
   e.g., rgba(255, 0, 0, 0.5) for a transparent red.
                                                                                     32
Example:
h1 {
    color:     red;             /* Named Color */
}
h2 {
    color:     rgb(0, 128, 0);         /* RGB Color */
}
h3 {
    color:     #0000ff;         /* Hexadecimal Color */
}
h4 {
    color:     rgba(255, 165, 0, 0.5); /* RGBA Color */
}
HTML Selectors
In CSS, selectors are used to target HTML elements for styling. You can use basic
selectors like element selectors (e.g., h1, p) to apply styles to all occurrences of an
element.
Example:
h1 {
    color: orange;
    font-size: 24px;
}
p {
      color: blue;
      text-align: center;
}
In this example, all h1 elements will be orange, and all p elements will have blue text
and be centered.
Styling
Classes allow you to define styles that can be applied to multiple elements. A class is
defined with a . followed by the class name and applied using the class attribute in
HTML.
Example:
In CSS
.heading-common {
    font-style: italic;
}
.text-red {
    color: red;
}
                                                                                          33
In HTML
<h2 class="heading-common text-red">This is styled with a
class</h2>
Here, the class heading-common applies italic style, and text-red changes the text
colour to red. Multiple classes can be applied by separating them with a space.
CSS ID’s
Unlike classes, IDs are unique and can only be used once per page. An ID is defined
with a # followed by the ID name and is applied using the id attribute in HTML.
Example
In CSS
#main-heading {
     color: purple;
     text-transform: uppercase;
}
In HTML
<h1 id="main-heading">This is a unique styled heading</h1>
The ID main-heading is applied to this h1 and makes the text purple and uppercase.
• A CSS file is just a text file that controls the styling of HTML pages.
• Using an external CSS file ensures consistency across all HTML pages in a project.
•   There are various ways to define colours, using names, RGB values, hex codes, or
    RGBA for transparency.
•   Classes can be reused on multiple elements, while IDs are unique to a single
    element.
                                                                                      34
A          ctivity
                                 35
S         tyling Text
Modern browsers will support around 300 different CSS properties. The good news is
that you do not have to remember them all. Most web developers can remember the
most common ones that they use, but will usually look up the rest when they need to
use them.
In this lesson you will learn a little more about styling text.
An excellent resource to look up the various CSS properties is the CSS Reference at
W3Schools website. You can click on any of the properties to get a full explanation on
how to use it, and the possible values.
CSS Properties
There are far too many text styling properties for us to explain them all. We will cover
only some of the most popular.
                                                                                           36
                                                            text-decoration-thickness:
text-decoration-    Sets the thickness of the line used for
                                                            5px;
thickness           text decoration.
                                                            text-decoration-thickness:
                                                            50%;
                                                            text-decoration-color: red;
                                                            text-decoration-color:
text-decoration-    Sets the colour of the line used for
                                                            #ff0000;
color               text decoration.
                                                            text-decoration-color:
                                                            rgb(234, 65, 97);
                                                            text-transform: uppercase;
                    Sets the transform of the text within a
text-transform                                              text-transform: lowercase;
                    <DIV> tag.
                                                            text-transform-capitalize;
                                                            line-height: normal;
                    Sets the distance between lines of
line-height                                                 line-height: 80%;
                    text.
                                                            line-height: 10px;
                    Increases the space between letters letter-spacing: 3px;
letter-spacing
                    of text.                                letter-spacing: -2px;
                    Increases the spacing between words
word-spacing                                                word-spacing: 20px;
                    of text
                                                            background-color: red;
                                                            background-color: #00ff00;
background-color    Sets the background color for text
                                                            background-color: rgb(57,
                                                            222, 187);
A ctivity
1.    The font-family property allows you to specify multiple fonts, and the browser will
      try the second font if the first one is unavailable.
2. The font-weight property can only accept values like normal and bold.
3.    The color property can be used to set the text color using a color name, hex
      code, or RGB value.
                                                                                       37
S        tyling Paragraphs
On a web page it is likely that you have many paragraphs of text. Paragraphs work fine
(using the <P></P> tags), however if you want more flexibility when it comes to the
styling of "blocks" then the best tag to use is the <DIV></DIV> tag.
The <DIV> tag creates a "container". You can think of these as being "areas" or "blocks"
on the web page. Each <DIV> tag can contain a lot of other HTML tags. The DIV tag
just helps to arrange things a lot easier.
You already know how to use CSS to style text. But, what if you wanted to style entire
areas of the web page. The best way to do this is break your page into areas using the
<DIV> tag. Then you can put various content into the DIV tag. For example, you could
put a paragraph (or paragraphs) of text in it. Or, you could create a DIV tag, and place
an image inside it.
Think of each DIV tag as being a "container". Not only DIV tags are containers. Almost
all HTML tags (like <BODY>, <UL>, <H1>, etc.) are also containers, and can be styled
accordingly.
Here are some handy CSS properties that can act on the entire container.
                                                                                       38
Table of CSS Properties
CSS
           Purpose                                             Examples of values
Property
                                                               #00cc00;
                                                               background-color:
                                                               rgb(224, 100, 56);
            Sets a background image for a container. make
            sure that you have the image in the correct file
background-                                                    background-image:
            location. The example to the right assumes you
image                                                          url("assets/myimage.gif");
            have an image called myimage.gif, and that it is
            stored in a folder called /assets.
            These properties are all used to "position" an
            element inside of its parent. For example, the
            following CSS (using an ID) can be used to
            position a <div> element at an exact location
            (150 pixels from the left and 120px from the top)
position
            inside of the <body> tag. The DIV is inside the
            BODY, so the BODY is the parent and the DIV is position: absolute;
left
            the child. You need to be very careful when        position: relative;
            placing things at exact positions on the screen, top: 50px;
top
            as it doesn't always end up looking like you want bottom: 135px;
            it to.                                             left: 200px;
bottom
                                                               right: 100px;
            #mydiv {
right
                position: absolute;
                left: 150px;
                top: 120px;
                border: 3px solid green;
            }
                                                               text-align: left;
            Sets how text is aligned if it is placed inside of text-align: right;
text-align
            the container.                                     text-align: center;
                                                               text-align: justify;
                                                                                       39
A            ctivity
In earlier versions of HTML there was an <embed> tag. This was used to embed
various file types into a web page. That <embed> tag is now deprecated (can you
remember what that means ? No. Look it up.).
HTML5, the version of HTML that is now in common use, offers two tags for us to use.
The first of these is used for video, and is the <video> tag.
The following HTML code snippet will place a video onto the web page.
                                                                                   40
The DIV tags are not necessary, but it always handy to place the video into a container
that you can then later style with CSS.
<div>
Take note of the attributes that are included in the <video> tag.
The width and height attributes specify the width and height of the video player. It is
important to use both of these, or the video may flicker when it plays. For best results
try and match these numbers to the actual width and height of the video (you can check
the video files properties for this), or some fraction of this. The original video provided is
at 1960x1080 resolution, and the code above sets the width and height to exactly have
of those to maintain the "aspect ratio".
The controls attribute instructs the browser to display play, pause, and stop buttons so
that the playback can be controlled.
You may have noticed that there are TWO <source> tags. This is a bit of a "safety"
feature. If the client browser is an older type and cannot play the first file type (the .mp4
file), then it will automatically try and play the second type of file (the .ogg file) instead.
There is another attribute, autoplay, that can also be used in the video tag. Browsers
often will not auto-play though, so in order to make sure that it does you should rather
use autoplay muted instead.
HTML5 provides the <audio> tag that we can use to place audio videos into a player on
the web page.
The following snippet of code will put the provided audio file onto the page.
<div>
  <audio controls>
     <source src="assets/music-sample.ogg" type="audio/ogg">
     <source src="assets/music-sample.mp3" type="audio/mpeg">
     <source src="assets/music-sample.wav" type="audio/wav">
     Your browser does not support the audio element.
  </audio>
<div>
Note that the <audio> tag has the controls attribute. This puts play, pause, stop buttons
on the player so the playback can be controlled. If you leave it off then there are not
buttons.
                                                                                             41
The reason for the multiple <source> tags is the same as for the video. If the browser is
unable to play the .ogg file then it will try the .mp3 version. If it still cant play that then it
will try the .wav version last.
If none of the versions will play, then the text (Your browser does not support the audio
element.) is displayed instead.
The <audio> tag also supports the autoplay muted attributes. If you just use autoplay on
its own then most Chromium based browsers (Chrome, Edge, Brave, etc.) will not auto
play.
Note: Safari browser does not support OGG files at this time.
A ctivity
2. The <video> tag is used to place audio files onto a web page in HTML5.
3. The controls attribute in the <video> tag instructs the browser to display play, pause,
   and stop buttons.
4. If the first <source> tag in a media element cannot be played, the browser will
   automatically try to play the second <source> tag.
5. The <audio> tag supports the autoplay muted attributes to ensure that audio plays
   automatically without sound in browsers.
                                                                                                42
C         ss Glossary
1. CSS (Cascading Style Sheets): A style sheet language used for describing the
   presentation of a document written in HTML or XML. CSS controls the layout of
   multiple web pages all at once.
2. CSS Properties: Attributes that define how HTML elements should be displayed.
   Each property has a specific purpose and can have multiple values. Common
   properties include width, height, margin, padding, border, background-color, and
   more.
3. font-family: A CSS property that specifies the type of font to be used for text.
   Multiple fonts can be listed as fallbacks.
4. font-style: This property sets the style of the font, such as normal or italic.
5. font-weight: Specifies the thickness of characters in text, with values like normal,
   bold, or numeric values from 100 to 900.
6. font-size: Sets the size of the font, which can be specified in pixels, percentages, or
   keywords like small, medium, and large.
7. color: Defines the color of the text, which can be represented in various formats
   such as named colors, hex codes, or RGB values.
8. text-decoration-line: Determines the type of line used for text decoration, including
   underline, overline, and line-through.
11. text-transform: Controls the capitalization of text within an element, with values like
    uppercase, lowercase, or capitalize.
12. line-height: Sets the vertical distance between lines of text, which can be specified
    in normal, percentages, or fixed pixel values.
16. background-image: Sets a background image for an element, requiring the correct
    file path.
                                                                                          43
17. position: A property that determines how an element is positioned within its parent
    container. Common values include static, relative, absolute, and fixed.
18. left, right, top, bottom: Properties used to define the exact position of an element
    when using the absolute or fixed position.
19. text-align: Controls the alignment of text within an element, with values like left,
    right, center, and justify.
20. HTML5: The latest version of HTML, which introduces new elements and attributes,
    including <video> and <audio> for multimedia content.
21. <video> tag: An HTML element used to embed video content in a web page. It
    includes attributes like controls, width, and height.
22. <audio> tag: An HTML element used to embed audio content in a web page. It also
    includes the controls attribute for playback control.
23. <source> tag: An HTML element used within <video> and <audio> tags to specify
    different media file formats. Browsers will attempt to play the first supported format
    listed.
24. autoplay: An attribute that allows media (audio or video) to start playing
    automatically when the page loads. Browsers often require muted to allow autoplay.
25. deprecated: A term indicating that a feature (like the <embed> tag) is outdated and
    should not be used in modern web development.
                                                                                             44
A
1.
           ctivities
     Scenario: You have been tasked with creating a personal webpage to introduce
     yourself to the world. This webpage will showcase your interests, hobbies, and
     some personal achievements.
1.2 Create Your CSS Style Guide for Your Personal Webpage
           Scenario: You are tasked with creating a CSS style guide for your
           personal webpage. This guide will define how your webpage will look,
           including fonts, colors, spacing, and layout.
                                                                                          45
           7. What background styles will you use?
              Determine whether you will use a solid color, gradient, or image for
              your background. Why did you choose this style?
P
1.
        ossible Answers
 <!DOCTYPE html>
 <html lang="en">
 <head>
     <meta charset="UTF-8">
     <meta name="viewport" content="width=device-width, initial-
 scale=1.0">
     <title>My Personal Webpage</title>
     <style>
         /* General Styles */
         body {
             font-family: Arial, sans-serif; /* Body font */
             background-color: #F8F9FA; /* Background color */
             margin: 0; /* Reset default margins */
             display: flex; /* Flexbox layout */
             flex-direction: column; /* Column direction */
             justify-content: space-between; /* Space between
 sections */
         }
         /* Header Styles */
         header {
             background-color: #007BFF; /* Header background
 color */
             color: white; /* Header text color */
             padding: 20px; /* Padding around header */
             text-align: center; /* Centered text */
         }
         /* Navigation Styles */
         nav {
             margin: 10px 0; /* Margin for navigation */
         }
                                                                                     46
        nav a {
            color: white; /* Link color */
            text-decoration: none; /* No underline */
            margin: 0 15px; /* Spacing between links */
        }
        nav a:hover {
            text-decoration: underline; /* Underline on hover
*/
        }
        h2 {
            margin: 20px 0; /* Margin for headings */
        }
        p {
              margin: 15px 0; /* Margin for paragraphs */
        }
        /* Footer Styles */
        footer {
            background-color: #007BFF; /* Footer background
color */
            color: white; /* Footer text color */
            text-align: center; /* Centered text */
            padding: 10px; /* Padding around footer */
        }
    </style>
</head>
<body>
     <header>
         <h1>Welcome to My Personal Webpage</h1>
     </header>
     <nav>
         <a href="#about">About Me</a>
         <a href="#hobbies">My Hobbies</a>
         <a href="#achievements">Achievements</a>
     </nav>
     <main>
         <div id="about">
             <h2>About Me</h2>
                                                                47
             <p>Hi! I'm [Your Name], a [your profession or
interests]. I love exploring new technologies and creating
innovative solutions.</p>
             <img src="assets/your-image.jpg" alt="A
representation of me" width="300"> <!-- Replace with your image
file -->
         </div>
        <div id="hobbies">
            <h2>My Hobbies</h2>
            <p>I enjoy [list your hobbies, e.g., painting,
hiking, coding]. Each hobby brings me joy and relaxation.</p>
        </div>
        <div id="achievements">
            <h2>Achievements</h2>
            <p>Some of my achievements include [list your
achievements, e.g., certifications, awards].</p>
        </div>
    </main>
   <footer>
       <p>© 2024 [Your Name]. All rights reserved.</p>
   </footer>
</body>
</html>
48