ZetCode

JavaScript dispatchEvent

last modified April 2, 2025

In this article, we explore the element.dispatchEvent method in JavaScript. This method allows developers to trigger custom events or simulate built-in events programmatically on DOM elements.

Basic Definition

The dispatchEvent method dispatches an Event at a specified EventTarget (element, document, window, etc.). This is useful for creating and triggering custom events or simulating user interactions.

To use dispatchEvent, you first need to create an event object using the Event constructor or specific event constructors like CustomEvent, MouseEvent, etc.

Basic Custom Event

This example demonstrates how to create and dispatch a simple custom event.

index.html
<!DOCTYPE html>
<html>
<head>
    <title>Basic Custom Event</title>
</head>
<body>

<button id="myButton">Click Me</button>
<p id="output">Waiting for event...</p>

<script>
    const button = document.getElementById('myButton');
    const output = document.getElementById('output');

    // Create event listener
    button.addEventListener('myEvent', () => {
        output.textContent = 'Custom event received!';
    });

    // Create and dispatch event
    const event = new Event('myEvent');
    button.dispatchEvent(event);
</script>

</body>
</html>

In this example, we create a button and a paragraph element. We add an event listener for a custom event named 'myEvent'. Then we create and dispatch this event immediately.

This demonstrates the basic workflow of creating, listening for, and dispatching custom events. The event is handled synchronously when dispatched.

Custom Event with Data

This example shows how to pass data with a custom event using CustomEvent.

index.html
<!DOCTYPE html>
<html>
<head>
    <title>Custom Event with Data</title>
</head>
<body>

<div id="container"></div>
<button id="trigger">Trigger Event</button>

<script>
    const container = document.getElementById('container');
    const trigger = document.getElementById('trigger');

    container.addEventListener('dataEvent', (e) => {
        container.innerHTML = `Received data: ${e.detail.message}`;
    });

    trigger.addEventListener('click', () => {
        const event = new CustomEvent('dataEvent', {
            detail: {
                message: 'Hello from custom event!'
            }
        });
        container.dispatchEvent(event);
    });
</script>

</body>
</html>

Here we use CustomEvent instead of the basic Event constructor. The detail property allows us to pass custom data with the event.

When the button is clicked, it dispatches a custom event with a message payload. The container element receives this event and displays the message.

Simulating Click Event

This example demonstrates how to simulate a native click event programmatically.

index.html
<!DOCTYPE html>
<html>
<head>
    <title>Simulate Click</title>
</head>
<body>

<button id="realButton">Real Button</button>
<button id="fakeButton">Simulate Click</button>
<p id="result"></p>

<script>
    const realButton = document.getElementById('realButton');
    const fakeButton = document.getElementById('fakeButton');
    const result = document.getElementById('result');

    realButton.addEventListener('click', () => {
        result.textContent = 'Real button clicked!';
    });

    fakeButton.addEventListener('click', () => {
        const clickEvent = new MouseEvent('click', {
            bubbles: true,
            cancelable: true,
            view: window
        });
        realButton.dispatchEvent(clickEvent);
    });
</script>

</body>
</html>

In this example, clicking the "Simulate Click" button programmatically triggers a click event on the "Real Button". We use MouseEvent to create a realistic click event.

The bubbles option makes the event bubble up the DOM tree, and cancelable allows it to be prevented, just like a real click.

Event Propagation Control

This example shows how to control event propagation when dispatching events.

index.html
<!DOCTYPE html>
<html>
<head>
    <title>Event Propagation</title>
</head>
<body>

<div id="parent">
    <div id="child">Click me or my parent</div>
</div>
<button id="dispatchBtn">Dispatch Custom Event</button>
<p id="log"></p>

<script>
    const parent = document.getElementById('parent');
    const child = document.getElementById('child');
    const dispatchBtn = document.getElementById('dispatchBtn');
    const log = document.getElementById('log');

    function logEvent(message) {
        log.textContent += message + '\n';
    }

    parent.addEventListener('customEvent', () => logEvent('Parent handler'));
    child.addEventListener('customEvent', () => logEvent('Child handler'));

    dispatchBtn.addEventListener('click', () => {
        log.textContent = '';
        const event = new Event('customEvent', {
            bubbles: false // Event won't bubble up
        });
        child.dispatchEvent(event);
    });
</script>

</body>
</html>

Here we demonstrate how the bubbles option affects event propagation. When set to false, the event only triggers handlers on the target element (child) and doesn't bubble up to the parent.

Try changing bubbles: false to true to see the difference in event propagation behavior.

Async Event Handling

This example shows how to handle dispatched events asynchronously.

index.html
<!DOCTYPE html>
<html>
<head>
    <title>Async Event Handling</title>
</head>
<body>

<button id="eventButton">Dispatch Event</button>
<div id="status">Ready</div>

<script>
    const button = document.getElementById('eventButton');
    const statusDiv = document.getElementById('status');

    document.addEventListener('asyncEvent', async (e) => {
        statusDiv.textContent = 'Processing...';
        await new Promise(resolve => setTimeout(resolve, 2000));
        statusDiv.textContent = `Completed: ${e.detail.task}`;
    });

    button.addEventListener('click', () => {
        const event = new CustomEvent('asyncEvent', {
            detail: { task: 'Data processing' }
        });
        document.dispatchEvent(event);
    });
</script>

</body>
</html>

In this example, we demonstrate handling a dispatched event with asynchronous code. The event handler uses async/await to simulate a long-running task.

When the event is dispatched, the UI updates immediately, then updates again after the async operation completes, showing how events can work with modern async JavaScript patterns.

Source

MDN dispatchEvent Documentation

In this article, we have explored the dispatchEvent method in JavaScript. This powerful feature enables custom event systems and simulation of user interactions for testing and advanced UI patterns.

Author

My name is Jan Bodnar, and I am a passionate programmer with extensive programming experience. I have been writing programming articles since 2007. To date, I have authored over 1,400 articles and 8 e-books. I possess more than ten years of experience in teaching programming.

List all JS DOM tutorials.