Skip to content

Latest commit

 

History

History
151 lines (107 loc) · 5.21 KB

README.md

File metadata and controls

151 lines (107 loc) · 5.21 KB

Frontend Mentor - Advice generator app solution

This is a solution to the Advice generator app challenge on Frontend Mentor. Frontend Mentor challenges help you improve your coding skills by building realistic projects.

Table of contents

Overview

The challenge

Users should be able to:

  • View the optimal layout for the app depending on their device's screen size
  • See hover states for all interactive elements on the page
  • Generate a new piece of advice by clicking the dice icon

Demo

Desktop A gif demo similar to the desktop version of the app

Links

My process

Built with

  • Semantic HTML5 markup
  • CSS custom properties
  • Flexbox
  • Mobile-first workflow
  • Vanilla JavaScript (DOM, Fetch API)

What I learned

  • Values open-quote and close-quote of the CSS property content

    • open-quote - Sets the content to be an opening quote.

    • close-quote - Sets the content to be a closing quote.

    • HTML

      <p>Hello World</p>
    • CSS

      p::before {
        content: open-quote;
      }
      
      p::after {
        content: close-quote;
      }
    • Result - after page load

      "Hello World"

  • HTML DOM Element cloneNode() method:

    • The cloneNode() method creates a copy of a node, and returns the clone.

    • The cloneNode() method clones all attributes and their values.

    • Set the deep parameter to true if you also want to clone descendants (children).

    • HTML

      <div id="hello">
        <p>Hello</p>
      </div>
      <div id="world">
        <p>World</p>
      </div>
    • JavaScript

      const hello = document.getElementById('hello');
      const world = document.getElementById('world');
      console.log(hello.cloneNode(false)); // <div id="hello"></div>
      console.log(world.cloneNode(true)); // <div id="world"><p>World</p></div>
  • <template> HTML tag - Used as a container to hold some HTML content hidden from the user when the page loads.

    • HTML

      <button onclick="showContent()">Show hidden content</button>
      <template id="myTemplate">
        <p>This paragraph is hidden from the user by default</p>
      <template>
    • JavaScript

      function showContent() {
        var template = document.getElementById("myTemplate");
        var p = template.content.cloneNode(true);
        document.body.appendChild(p);
      }
    • Result - after calling the showContent() method

      <button onclick="showContent()">Show hidden content</button>
      <template id="myTemplate">
        <p>This paragraph is hidden from the user by default</p>
      <template>
      <p>This paragraph is hidden from the user by default</p>

Useful resources

Author