Home HTML Data Types DOM JavaScript JS Debugging

How does HTML work?

Similar function to Markdown, syntax defines how stuff should be displayed

  • HTML is based on beginning and closing tags <tagname>content</tagname>
    • Note the “/” on the ending or closing tag of the pair

Compare markdown to html below

This below example shows comparison of a heading and paragraph. Click on links to see many more HTML examples.

%%markdown

### Markdown: This is a Heading

This is a paragraph

Markdown: This is a Heading

This is a paragraph

%%html

<h3>HTML: This is a Heading</h3>
<p>This is a paragraph.</p>

HTML: This is a Heading

This is a paragraph.

Attributes

  • Learn about attributes
  • Tags can have additional info in the form of attributes
  • Attributes usually come in name/value pairs like: name=”value”
<tagname attribute_name="attribute_value" another_attribute="another_value">inner html text</tagname>
  • href example with attribute for web link and inner html to describe link
<a href="https://www.w3schools.com/html/default.asp">Visit W3Schools HTML Page</a>

Sample Markdown vs HTML Tags

Image Tag - Markdown

![describe image](link to image)

Image Tag - HTML

<!-- no content so no end tag, width/height is optional (in pixels) -->
<img alt="describe image" src="link to image" width="100" height="200">

Link Tag - Markdown

[link text](link)

Link Tag - HTML

<a href="link">link text</a>

Bolded Text - Markdown

**Bolded Text**

Bolded Text - HTML

<strong>Bolded Text</strong>

Italic Text - Markdown

*Italic Text*

Italic Text - HTML

<i>Italic Text</i>

More tags (not really in markdown)

P tag (just represeants a paragraph/normal text)

<p>This is a paragraph</p>

Button

<button>some button text</button>

Div (groups together related content)

<!-- first information -->
<div>
    <!-- notice how tags can be put INSIDE eachother -->
    <p>This is the first paragarph of section 1</p>
    <p>This is the second paragraph of section 1</p>
</div>

<!-- second information -->
<div>
    <!-- notice how tags can be put INSIDE eachother -->
    <p>This is the first paragarph of section 2</p>
    <p>This is the second paragraph of section 2</p>
</div>

Resources

  • https://www.w3schools.com/html/default.asp
  • I will show a demo of how to find information on this website

HTML Hacks

  • Below is a wireframe for an HTML element you will create. A wireframe is a rough visual representation of HTML elements on a page and isn’t necessarily to scale or have the exact styling that the final HTML will have. Using the syntax above, try to create an HTML snippet that corresponds to the below wireframe.
  • The “a tags” can contain any links that you want

wireframe for html hacks

%%html
<div class="container">
    <div class="wrappertop">
        <p class="paragraph">p</p>
        <button class="greenButton" onclick="flipText()">button</button>
        <div class="floatingDivTop">div</div>
    </div>
    <div class="wrapperbtm">
        <div class="floatingDivBtm">div</div>
        <a href="https://www.youtube.com/watch?v=dQw4w9WgXcQ">
            <div class="link">a</div>
        </a>
        <a href="https://nighthawkcoders.github.io/teacher/basics/html">
            <div class="link">a</div>
        </a>
        <p class="paragraph">p</p>
    </div>
</div>

<script>
    const animalFacts = [
    "Penguins can jump up to 6 feet in the air.",
    "Kangaroos cannot walk backward.",
    "Octopuses have three hearts.",
    "Owls can rotate their heads 270 degrees.",
    "A group of flamingos is called a 'flamboyance.'",
    "Elephants are excellent swimmers.",
    "Cats have a unique nose print, just like human fingerprints.",
    "Honeybees can recognize human faces.",
    "The cheetah is the fastest land animal.",
    "A newborn kangaroo is the size of a lima bean.",
    "A group of crows is called a 'murder.'",
    "A chameleon's tongue is longer than its body.",
    "Polar bears are left-handed.",
    "The mantis shrimp has 16 color receptors in its eyes."
    ];

    let factCount = 0;

    function flipText () {
        const paragraph = document.getElementsByClassName("paragraph")[0]
        if (factCount == animalFacts.length) {
            factCount = 0;
        }
        const randomFact = animalFacts[factCount]
        paragraph.innerText = randomFact;
        factCount++
        return;
    }
</script>

<style>
    .container {
        padding: 10px 10px 10px 10px;
        width: 640px;
    }
    .wrappertop {
        background-color: #ffff;
        border: 3px solid black;
        padding: 5px;
        padding-bottom: 7.5%;
        margin-bottom: 25px;
    }
    .wrapperbtm {
        background-color: #ffff;
        border: 3px solid black;
        padding: 5px;
        margin-bottom: 10px;
        padding-bottom: 0%;
    }
    .paragraph {
        border: 3px solid red;
        color: red;
        margin-top: 0px;
        margin-bottom: 5px;
        text-align: center;
        font-size: 28px;
        font-weight: bold;
    }
    .greenButton {
        position: relative;
        border: 3px solid #59ff00;
        background-color: #ffff;
        color: #59ff00;
        font-size: 24px;
        font-weight: bold;
        width: 33%;
        z-index: 10;
    }
    .greenButton:hover {
        position: relative;
        border: 3px outset #59ff00;
        background-color: #ffff;
        color: #59ff00;
        font-size: 24px;
        font-weight: bold;
        width: 33%;
        z-index: 10;
    }
    .greenButton:active {
        position: relative;
        border: 3px inset #59ff00;
        background-color: #ffff;
        color: #59ff00;
        font-size: 24px;
        font-weight: bold;
        width: 33%;
        z-index: 10;
    }
    .floatingDivTop {
        position: relative;
        text-align: center;
        margin-top: -40px;
        color: black;
        font-size: 35px;
        font-weight: bold;
    }
    .floatingDivBtm {
        position: relative;
        text-align: center;
        color: black;
        font-size: 35px;
        margin-bottom: -75px;
        padding-top: 36px;
        font-weight: bold;
    }
    .link {
        position: relative;
        border: 3px solid blue;
        color: blue;
        background-color: #ffff;
        width: 33%;
        text-align: center;
        font-size: 24px;
        font-weight: bold;
        margin-bottom: 5px;
        z-index: 10;
    }
</style>

p

div
div

p