Event Bubbling Vs. Event Capturing
Event bubbling and event capturing are two phases of the event propagation process in the DOM (Document Object Model) when an event occurs on an element within a web page. These mechanisms define the order in which event handlers are executed when an event is triggered on a nested structure of HTML elements. Understanding these phases is important for managing event handling and interactions in JavaScript.
Event Bubbling
Event bubbling is the default behavior in most browsers. When an event is triggered on an element, it starts at the target element and then bubbles up through its parent elements in the DOM hierarchy, one level at a time, until it reaches the root of the document (the window object).
Click anywhere inside Div
Event Capturing (aka Trickling)
Event capturing is the opposite of bubbling. It's a less common behavior where the event starts from the root of the document and trickles down through the DOM hierarchy to the target element. However, it's important to note that not all browsers support event capturing by default.
With the above code, if you click on the "Inner div," you'll see both event handler outputs in the console, but in the opposite order compared to event bubbling:
Stopping Propagation
You can use the event.stopPropagation() method within an event handler to prevent further propagation in either the bubbling or capturing phase. This can be useful to stop an event from triggering other handlers in the propagation chain.
In this case, if you click on the "Inner div," only the handler for the "Inner div" will run.
Conclusion
Understanding event bubbling and capturing is crucial for controlling how events propagate through the DOM and for managing interactions within complex structures of HTML elements. It allows you to create more organized and efficient event handling in your web applications.
- JavaScript Interview Questions (Part2)
- JavaScript Interview Questions (Part3)
- Is JavaScript a true OOP language?
- Advantages and Disadvantages of JavaScript
- Difference Between JavaScript and ECMAScript?
- What is noscript tag?
- Escaping Special Characters in JavaScript
- What is undefined x 1 in JavaScript?
- Logical operators in JavaScript
- Difference between '=', '==' and '===' operators in JS
- How to loop through objects in JavaScript?
- How to write html code dynamically using JavaScript?
- How to add html elements dynamically with JavaScript?
- How to load another html page from javascript?
- What Is The Disadvantages Using InnerHTML In JavaScript?
- What is Browser Object Model
- How to detect the OS on the client machine in JavaScript?
- Difference between window, document, and screen in Javascript?
- Difference between the substr() and substring() in JavaScript?
- How to replace all occurrences of a string in JavaScript?
- Test a string as a literal and as an object in JavaScript
- What is Associative Array in JavaScript
- What is an anonymous function in JavaScript?
- What is the use of 'bind' method in JavaScript?
- Pure functions Vs. Impure functions in javascript
- Is Javascript a Functional Programming Language?
- What's the Difference Between Class and Prototypal Inheritance?
- Javascript, Pass by Value or Pass by Reference?
- How to prevent modification of an object in Javascript?
- What is 'this' keyword in JavaScript?
- How Does Function Hoisting Work in JavaScript?
- What do mean by NULL in Javascript?
- What does the delete operator do in JavaScript?
- What is the Infinity property used for in Javascript?
- What is "strict mode" and how is it used in JavaScript?
- What is the difference between call and apply in JavaScript
- Entire content of a JavaScript source file in a function block?
- What is an immediately-invoked function expression?
- What is escape & unescape String functions in JavaScript?
- Instanceof operator in JavaScript
- What Are RESTful (REpresentational State Transfer)Web Services?
- What is Unobtrusive JavaScript & Why it's Important?
- What Does JavaScript Void(0) Mean?
- What are JavaScript Cookies?
- Difference between Client side JavaScript and Server side JavaScript
- TypeError: document.getelementbyid(...) is null
- Uncaught TypeError: Cannot read property of undefined In JavaScript
- Null and Undefined in JavaScript