myHotTake

Tag: permissions

  • How Does JavaScript Handle Browser Notification Requests?

    If you find this story helpful or entertaining, feel free to like or share it with others who might enjoy a splash of creativity mixed with code!


    I’m a competitive swimmer, and the pool is my browser. Before I dive into the water, I need to make sure everything is set up just right. Let’s say I want to wear my new, shiny swim goggles—these represent the browser notifications. But before I put them on, I need to ask the coach for permission because they have final say over what gear is allowed in the pool. This is like requesting permission for browser notifications in JavaScript.

    So, I approach my coach and say, “Hey, can I wear these goggles today?” This is similar to using the Notification.requestPermission() method in JavaScript, where I’m asking the browser for permission to enable notifications.

    Now, my coach has a few options. They can nod and say, “Yes, go ahead!” which is like the permission being granted, indicated by the promise resolving to “granted.” Or, they might say, “No, not today,” which represents a “denied” permission. Lastly, they might say, “Maybe later,” which is akin to “default,” meaning no decision has been made yet.

    If the coach says yes, I’m all set to dive in with my goggles, just like when the browser grants permission, and notifications can be shown. If they say no, then I have to stick with my old gear, which is similar to not being able to display notifications. And if they are undecided, well, I wait a bit, just like a user might be prompted later.

    Just like asking my coach is a crucial step before hitting the water, requesting permission in JavaScript is essential before diving into the world of browser notifications.


    Continuing with my competitive swimming analogy, imagine I’ve approached my coach to ask for permission to wear my shiny goggles. This is akin to the JavaScript Notification.requestPermission() method. Here’s how I’d write that in code:

    // Asking the browser for notification permission
    Notification.requestPermission().then(function(permission) {
        if (permission === 'granted') {
            console.log("Permission granted: Goggles are on!");
            // Here, I would initiate a notification, like starting a swim race
            new Notification('Race Alert!', {
                body: 'The race is about to start!',
                icon: 'swim_icon.png'
            });
        } else if (permission === 'denied') {
            console.log("Permission denied: No goggles today.");
        } else {
            console.log("Permission undecided: Waiting for the coach's call.");
        }
    });

    In this code snippet, I’m essentially standing at the edge of the pool, waiting for my coach’s response. When the promise resolves, I check the permission status:

    • “granted”: The coach says, “Yes, go ahead!” I put on my goggles and start the race. In code, this means I can create a new notification.
    • “denied”: The coach shakes their head, meaning I can’t use the goggles. Thus, no notifications can be shown.
    • “default”: The coach hasn’t made a decision yet, so I’m still waiting on the sidelines.

    Key Takeaways

    • Analogy Recap: Just as I need my coach’s permission to wear goggles in a swim race, we need the browser’s permission to show notifications.
    • JavaScript Method: Notification.requestPermission() is used to request this permission.
    • Handling Responses: Check the response to determine if notifications can be shown, similar to how I check my coach’s response before diving in.
    • Real-World Application: Understanding this process is crucial for creating user-friendly web applications where timely notifications enhance the user experience.