DEV Community

Cover image for Build a note app with JavaScript component.
Ayobami Ogundiran
Ayobami Ogundiran

Posted on • Edited on

Build a note app with JavaScript component.

Sure, you have learned about web and React components but today, I will show you JavaScript components as introduced by koras.js.

You might be wondering “What is a JavaScript component?”. They're no-build reusable UI components that work in browsers and servers without a virtual DOM or tagged templates.

It is similar to React components but with some interesting twists. You can learn more about it from koras.js docs.

Seeing is believing. Let’s build a note app with it. The image below shows the look of what we’re going to build and you can use it in real time without any building process at Noteapp

note app image

Now, let’s write the code.

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <meta http-equiv="X-UA-Compatible" content="ie=edge" />
    <title>HTML + CSS</title>
    <link rel="stylesheet" href="styles.css" />
  </head>
  <body>
    <div id="root"></div>
    <script type="module">
      //Note app code goes here.
    </script>
  </body>
</html>
Enter fullscreen mode Exit fullscreen mode

The code above shows the HTML structure of the app. The code below is for the main operations.

import {
  $render,
  $register
} from "https://cdn.jsdelivr.net/npm/@codingnninja/koras/dist/esm/koras.min.js";

function Notes() {
  function getNotes() {
    return localStorage.getItem("notes") ?? "";
  }


  function saveNote(event) {
    $select(".note[delete|textContent=write note...]");
    const notes = $select("#notes");
    localStorage.setItem("notes", notes.innerHTML);
  }


  return `
    <div id="container">
      <div id="notes" data-append="#notes">
        ${getNotes()}
          <div
            class="note"
            onblur="${saveNote()}"
            contenteditable=""
          >write note...</div>
      </div>
      <button
        class="add-note-btn"
        onclick="$render(Notes)"
      > + </button>
    </div>
  `;
}

$register(Notes);  
$render(Notes);
Enter fullscreen mode Exit fullscreen mode

Though the code is self explanatory, let’s explain it a bit. We import $render and $register from koras.js to render our note app without any build process.

$register is used to prepare JavaScript components for rendering with $render. That means we need to register a component before rendering it.

Notes component contains two local functions named getNotes and saveNotes.

function getNotes() {
  return localStorage.getItem("notes") ?? "";
}
Enter fullscreen mode Exit fullscreen mode

getNotes gets notes from the localstorage or returns an empty string if nothing is found.

saveNote grabs all the children of the tag containing all notes and stores them in the localstorage in form of an HTML string.

function saveNote(event) {
  $select(".note[delete|textContent=write note...]");
  const notes = $select("#notes");
  localStorage.setItem("notes", notes.innerHTML);
}
Enter fullscreen mode Exit fullscreen mode

$select is another utility provided by koras.js to access and manipulate the DOM with ease.

$select is used, in this case, to delete any note containing “write note…” to avoid storing them alongside the real notes.

The return section of Notes component is what appears in the DOM and it is pure HTML.

return `
  <div id="container">
    <div id="notes" data-append="#notes">
      ${getNotes()}
      <div
        class="note"
        onblur="${saveNote()}"
        contenteditable=""
      >write note...</div>
    </div>
    <button
      class="add-note-btn"
      onclick="$render(Notes)"
     > + </button>
   </div>
 `;
Enter fullscreen mode Exit fullscreen mode

Notes tag that represents the component is identified with id=“notes” and data-append informs the component to add a new child whenever it is rendered.

So, the component is designed to add a new note whenever the add note button (+) is clicked.

Everything works together to make a note app with the minimal and most concise code snippet ever possible to create a note app in JavaScript whether you use a framework or vanilla JavaScript.

You might be wondering how and why this works? If you want to know more about that, check koras.js docs and don’t forget to star the project on GitHub at koras.js.

Top comments (0)