How to Create Custom Events in JavaScript
Core points
- JavaScript event handling is the basis of all client applications, but they are associated with DOM elements and may not be flexible enough. JavaScript custom events solve this problem, providing greater flexibility and ease of maintenance.
- Creating JavaScript custom events includes passing event names, details, and options to a new
CustomEvent
object. After creation, you can use thedispatchEvent
method to dispatch this event on a specific element. - Multiple handlers can subscribe to custom events, so that different actions can be performed based on the event. Chrome, Firefox, and Opera support custom events, and some JavaScript libraries also provide support.
JavaScript event handling is the basis of all client applications. When an event occurs on a target element (such as button clicks, mouse movements, form submissions, etc.), the handler function is executed. An event object is passed to the handler, which provides various properties and many methods to block the default operation. One disadvantage is that events are closely linked to DOM elements. Consider a simple form that accepts user comments:
<label for="msg">你的留言</label><input type="text" id="msg"><button type="submit" form="msgbox">发送</button> <form id="msgbox"></form>
When submitting the form, we can write a handler to echo the message to the screen, for example:
document.getElementById("msgbox").addEventListener("submit", function(e) { e.preventDefault(); var msg = e.currentTarget.getElementById("msg").value.trim(); if (msg) { alert(msg); } }, false);
What if we also want to send a message as a tweet, store it on the server, or perform other actions? For the existing event delegation method, we have two options:
-
Add more code in existing handlers. This is not flexible enough because every time a feature is added, changed, or deleted, the handler function needs to be updated and tested. Posted messages can have dozens of uses, and we are trying to apply them all to the same code block.
-
Create more event handlers for each purpose. This will produce more elegant code, but will cause maintenance issues. First, each function must perform similar operations to extract and verify messages. What if we need to change the form? Just renaming the ID requires changing the event handling code for each subscriber.
Wouldn't it be nice if we could simply trigger a custom "newMessage" event when posting a valid message? It would be even better if we could monitor document
or body
tags instead of referencing specific form nodes. Custom events allow us to do this. Triggering a custom event is simple; we pass the name, details, and options to the new CustomEvent
object:
var event = new CustomEvent( "newMessage", { detail: { message: "Hello World!", time: new Date(), }, bubbles: true, cancelable: true } );
In this example, "newMessage" is the custom event type. The second parameter is an object with three attributes:
detail
: A child object that provides custom information about events. In this example, we added a message and time.bubbles
: Iftrue
, the event will bubble to the ancestor of the element that triggered the event.cancelable
: If it istrue
, you can use thestopPropagation()
method of the event object to cancel the event.
Now, we need to dispatch this event on a specific element, for example:
<label for="msg">你的留言</label><input type="text" id="msg"><button type="submit" form="msgbox">发送</button> <form id="msgbox"></form>
Any number of handlers can subscribe to this event using the following code:
document.getElementById("msgbox").addEventListener("submit", function(e) { e.preventDefault(); var msg = e.currentTarget.getElementById("msg").value.trim(); if (msg) { alert(msg); } }, false);
Demo Page
This example demonstrates the technique: View custom event demo page. The standard event handler looks for submissions of the HTML form above. This function gets the current message and assuming it is valid, a new "newMessage" event is dispatched.
var event = new CustomEvent( "newMessage", { detail: { message: "Hello World!", time: new Date(), }, bubbles: true, cancelable: true } );
The handler can now subscribe to the "newMessage" event. The event is triggered only if a valid message exists, and since bubbles
is set to true
, the event can be applied to the form or any of its ancestors, such as the root document
, for example:
document.getElementById("msgbox").dispatchEvent(event);
The message itself can be extracted from the detail.message
attribute of the event object.
Browser compatibility
At the time of writing, Chrome, Firefox, and Opera support CustomEvent
objects. It is available in the nightly version of Safari, so it will likely be available in that browser soon. This object is not supported in IE9 and below. Fortunately, several JavaScript libraries support custom event delegates, so stay tuned for SitePoint to get a cross-browser solution soon.
(The FAQs part is omitted here because it does not match the pseudo-original goal and is too long.)
The above is the detailed content of How to Create Custom Events in JavaScript. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Frequently Asked Questions and Solutions for Front-end Thermal Paper Ticket Printing In Front-end Development, Ticket Printing is a common requirement. However, many developers are implementing...

JavaScript is the cornerstone of modern web development, and its main functions include event-driven programming, dynamic content generation and asynchronous programming. 1) Event-driven programming allows web pages to change dynamically according to user operations. 2) Dynamic content generation allows page content to be adjusted according to conditions. 3) Asynchronous programming ensures that the user interface is not blocked. JavaScript is widely used in web interaction, single-page application and server-side development, greatly improving the flexibility of user experience and cross-platform development.

There is no absolute salary for Python and JavaScript developers, depending on skills and industry needs. 1. Python may be paid more in data science and machine learning. 2. JavaScript has great demand in front-end and full-stack development, and its salary is also considerable. 3. Influencing factors include experience, geographical location, company size and specific skills.

Discussion on the realization of parallax scrolling and element animation effects in this article will explore how to achieve similar to Shiseido official website (https://www.shiseido.co.jp/sb/wonderland/)...

Learning JavaScript is not difficult, but it is challenging. 1) Understand basic concepts such as variables, data types, functions, etc. 2) Master asynchronous programming and implement it through event loops. 3) Use DOM operations and Promise to handle asynchronous requests. 4) Avoid common mistakes and use debugging techniques. 5) Optimize performance and follow best practices.

The latest trends in JavaScript include the rise of TypeScript, the popularity of modern frameworks and libraries, and the application of WebAssembly. Future prospects cover more powerful type systems, the development of server-side JavaScript, the expansion of artificial intelligence and machine learning, and the potential of IoT and edge computing.

How to merge array elements with the same ID into one object in JavaScript? When processing data, we often encounter the need to have the same ID...

Data update problems in zustand asynchronous operations. When using the zustand state management library, you often encounter the problem of data updates that cause asynchronous operations to be untimely. �...
