WDD 131: Dynamic Web Fundamentals

Event Handling

Overview

Handling events in JavaScript is a fundamental part of building interactive web pages. In this activity, you'll learn all about the different events you can handle, how to handle them, and how to pass data between the event handler and the rest of your code.

"Events are things that happen in the system you are programming — the system produces (or "fires") a signal of some kind when an event occurs, and provides a mechanism by which an action can be automatically taken (that is, some code running) when the event occurs. Events are fired inside the browser window, and tend to be attached to a specific item that resides in it. " - MDN

Prepare

  1. Reference: JavaScript Events - WDD Learning Modules
  2. Practice: DOM Events - Ponder Activities - WDD Learning Modules
  3. Practice: Some common DOM event concepts/use cases. These are just a few examples, and there are many other events and use cases.
    • Click Event: Triggered when a user clicks on an element. It's widely used for handling button clicks, link clicks, or any interaction involving a mouse click.
      buttonElement.addEventListener('click', function() {
        // Code to execute when the element is clicked
      });

      The addEventListener method takes two arguments: the event name and a function to execute when the event is triggered. The function is called an event handler. We will learn more about writing functions later in the course. For now, just know that the function is a block of code that will be executed when the event is triggered. The function is also called a callback function because it is called back when the event is triggered.

    • Keyup Event: Triggered when a key is released. Useful for handling keyboard input.
      buttonElement.addEventListener('keyup', function() {
        // Code to execute when a key is released
      });
    • DOMContentLoaded Event: Triggered when the HTML document has been completely parsed and all deferred scripts have been executed. It's widely used for initializing JavaScript applications.
      document.addEventListener("DOMContentLoaded", function() {
        // Code to execute when the DOM is parsed
      });

Activity Instructions

Example screen shot of Book of Mormon chapter application

This activity adds functionality to the BOM Top 10 application started in the previous learning activity on the DOM. We will organize the code to respond to the Add Chapter button click in order to build the list item. In addition, the delete button functionality will be added along with some user interface expectations.

  1. Open up your JavaScript file that is supporting the bom.html application if needed.
  2. Create a click event listener for the Add Chapter button using an addEventListener.
    Check Your Understanding
    button.addEventListener('click', function() {
      // Code to execute when the button is clicked
    });
  3. Within the Add Chapter button click event function block ( between the opening can closing of the callback function argument { ... }, do the following:
    • Check to make sure the input is not blank before doing the following remaining tasks in this list. using an if block, otherwise provide a message or at least do nothing and return the .focus() to the input field.
      Check Your Understanding
      if (input.value.trim() !== '') { ... }

      What does the .trim() method do?
      Should an else branch be added to this conditional?
      What code should go into the condition true block { ... }?

    • Move the code that you wrote in the last activity into this if block in order to support the correct flow of the program.
      Check Your Understanding The user clicks Add Chapter button and the program checks to make sure that the input field is not empty. Then it is OK to start creating and populating elements.
    • Add an event listener to the delete button that removes the li element when clicked.
      Check Your Understanding
      deleteButton.addEventListener('click', function () {
        list.removeChild(li);
        input.focus();
      });
    • Change the input value to nothing or the empty string to clean up the interface for the user.
      Check Your Understanding
      input.value = '';
    • Regardless if a list item was created or not, the focus (active cursor) should be sent to the input element.
      Check Your Understanding
      input.focus();

Testing & Submission