JavaScript EVENT HANDLING involves defining functions or code snippets that are executed in response to specific events occurring in a web page.
Javascript Handling event
Here's an overview of how you can define event handlers in JavaScript :
Basic Event Handlers
1. Inline Event Handlers
You can define event handlers directly in HTML elements using the on
attribute. For example, to handle a button click event, you can define an inline event handler like this:
<button onclick="handleClick()">Click me</button>
In this example, the onclick attribute specifies the event and the associated JavaScript function handleClick that will be executed when the button is clicked.
2. DOM Event Handlers
JavaScript provides methods to dynamically attach event handlers to HTML elements using the Document Object Model (DOM). Here's an example of attaching an event handler to a button using DOM methods:
<button id="myButton">Click me</button>
<script>
// Get the button element by its ID
const button = document.getElementById('myButton');
// Attach an event listener to the button
button.addEventListener('click', handleClick);
// Event handler function
function handleClick() {
console.log('Button clicked!');
}
</script>
In this case, the addEventListener method is used to register the click event on the button element. The associated Event handler function, handleClick, will be called when the button is clicked.
3. Mouseover and Mouseout
<div id="myElement" onmouseover="handleMouseOver()" onmouseout="handleMouseOut()">Hover over me</div>
<script>
// Function called when mouseover event occurs
function handleMouseOver() {
console.log('Mouse over the element');
}
// Function called when mouseout event occurs
function handleMouseOut() {
console.log('Mouse out of the element');
}
</script>
In this example, we have a <div> element with the ID myElement. We attach the onmouseover attribute to the element, which specifies the handleMouseOver() function to be executed when the mouse pointer moves over the element. Similarly, the onmouseout attribute is used to specify the handleMouseOut() function, which is executed when the mouse pointer moves out of the element.
4. Event Listener Syntax
The general syntax for adding event listeners using the addEventListener method is as follows:
<button id="myButton">Click me</button>
element.addEventListener(event, handlerFunction);
- element : The HTML element to which you want to attach the event listener.
- event : The name of the event (e.g., 'click', 'keyup', 'submit') that you want to handle.
- handlerFunction : The JavaScript function that will be called when the event occurs.
You can define the event handler function separately or use an anonymous function directly in the addEventListener call.
Advanced Event Handlers
1. Event Listeners with Event Object
Use event listeners with the event object to get additional information about the event.
<button id="myButton">Click me</button>
<script>
const button = document.getElementById('myButton');
button.addEventListener('click', handleClick);
function handleClick(event) {
console.log('Button clicked!');
console.log('Event type:', event.type);
console.log('Event target:', event.target);
}
</script>
In this example, an event listener is added using the addEventListener method. The click event triggers the handleClick() function. The function logs a message to the console indicating the button was clicked. Additionally, it accesses properties of the event object (event.type and event.target) to log the event type ('click') and the target element (the button) to the console.
2. Event Delegation
Implement event delegation to handle events on multiple elements efficiently.
<ul id="myList">
<li>Item 1</li>
<li>Item 2</li>
<li>Item 3</li>
</ul>
<script>
const list = document.getElementById('myList');
list.addEventListener('click', handleItemClick);
function handleItemClick(event) {
if (event.target.tagName === 'LI') {
console.log('Item clicked:', event.target.textContent);
}
}
</script>
In this example, a click event listener is added to the <ul> element instead of attaching individual event handlers to each <li> element. When a click event occurs,
the handleItemClick()
function is called. It checks if the clicked target element has the tag name 'LI' and logs the text content of the clicked list item.
Resources for Further Learning
Explore the possibilities and create unique effects on your web pages by using the interactive code editor
HTML
Write and customize HTML code
CSS
Add style and design to your web pages with CSS
JavaScript
Enhance interactivity with JavaScript code