myHotTake

Tag: web alerts

  • How Do JavaScript Notifications Mirror Swim Coaching?

    If you find this story helpful or entertaining, feel free to give it a like or share it with others who might enjoy it too!


    I’m a competitive swimmer, and my coach is eager to keep me informed about my performance and upcoming swim meets. Think of the Notification object in JavaScript as my coach’s way of sending me messages. Each message has several parts, much like a notification does.

    First, there’s the title of the notification. In swim terms, this is like my coach yelling, “Hey, there’s a meet this Saturday!” It’s the eye-catching bit that grabs my attention in the midst of my practice, much like how a title grabs the user’s attention when a notification pops up on their screen.

    Next is the body of the notification. This is akin to my coach diving into details about the meet: the location, the start time, and the events I’ll be swimming in. It’s the informative part that gives me context, just like how the body of a notification provides more information to the user.

    There’s also the icon, which could be compared to my coach waving his favorite swim towel or wearing a distinctive cap. It’s a visual cue that helps me quickly recognize who’s calling out to me, similar to how an icon in a notification helps users identify the source of the message at a glance.

    Additionally, there’s the tag, which is like my coach giving me a unique identifier for each meet or message. He might say, “This is about the Regional Championships,” distinguishing it from other messages I might receive. In the world of notifications, a tag can help group or replace existing notifications, ensuring clarity and organization.

    Lastly, there’s the actions part of a notification. This is similar to my coach giving me options on how to respond—perhaps suggesting I either confirm my attendance or ask questions about the meet. In JavaScript, actions provide users with options on what to do next, making the notification interactive.

    So, every time my coach communicates with me during training, it’s like receiving a well-structured Notification object, each component serving a specific purpose to keep me informed and prepared. Just as I rely on my coach’s messages to navigate the swimming world, developers use notifications to effectively communicate with users.


    In JavaScript, creating a Notification object is like my coach crafting the perfect message to keep me informed and ready for my swim meets. Here’s how we can create a notification, akin to how my coach communicates with me:

    // Check if the browser supports notifications
    if ("Notification" in window) {
      // Request permission to display notifications
      Notification.requestPermission().then(permission => {
        if (permission === "granted") {
          // Create a notification
          const notification = new Notification("Swim Meet Alert!", {
            body: "Regional Championships on Saturday at 10 AM. Don't forget your gear!",
            icon: "swim-icon.png",
            tag: "meet-2023",
            actions: [
              { action: 'confirm', title: 'Confirm Attendance' },
              { action: 'details', title: 'More Details' }
            ]
          });
        }
      });
    }

    Breaking it down:

    • Title: "Swim Meet Alert!" shouts to grab attention, just like my coach’s initial call.
    • Body: This part, "Regional Championships on Saturday...", provides the details, much like the specifics about the meet.
    • Icon: "swim-icon.png" serves as the visual cue, similar to my coach’s distinctive gear.
    • Tag: "meet-2023" is the unique identifier, ensuring that if another notification about the same meet comes through, it doesn’t add confusion.
    • Actions: These options, like ‘Confirm Attendance’, are interactive elements for the user to engage with, just as my coach might offer me choices.

    Key Takeaways:

    1. Purposeful Structure: Just as a well-structured message from a coach keeps a swimmer informed, a Notification object must be carefully structured to communicate effectively with users.
    2. Attention to Detail: Each component of the notification serves a specific purpose, ensuring clarity and engagement.
    3. User Interaction: Including actions within a notification encourages user interaction, enhancing the overall experience.
    4. Browser Compatibility: Always check for browser support and request permission to display notifications, ensuring that your message reaches the user effectively.