data:image/s3,"s3://crabby-images/b5c57/b5c578d27f14297d3e252cc580203d8d94169e24" alt="Appendnode elements of programming interviews"
data:image/s3,"s3://crabby-images/9a0a9/9a0a9d2f5c2f57e6554508804984ab63dd294746" alt="appendnode elements of programming interviews appendnode elements of programming interviews"-js.png)
Here's the diagram to help you visualise this easily: 💡 In the event capturing phase, the event is first captured until it reaches the target element Now, if you click element2, you will see element1 is clicked is printed first followed by element2 is clicked. For element2, omitting or passing false will register the event handler in the bubbling phase. We have added true for useCapture parameter indicating that we are registering our event handler for element1 in the capturing phase. And you, as a web developer, can register your event handler in this phase by setting true as the third argument inside the addEventListener method. In the event capturing phase, the event is first captured until it reaches the target element ( event.target). 💡 Event bubbling is just one side of the coin Event capturing is the other. We mostly have been dealing with event bubbling when working with frameworks like React and never think much of another phase which is Event Capturing. The event flow mechanism in the W3C event model is Bi-directional. Now, the interesting bit is that event flow is not uni-directional, as you might have assumed. 💡 In event bubbling the innermost target element handles the event first and then it bubbles up in the DOM tree
data:image/s3,"s3://crabby-images/d959f/d959fd0a4eaff3883fe57aa2d972ebaa388a359b" alt="appendnode elements of programming interviews appendnode elements of programming interviews"
In event bubbling the innermost target element handles the event first, and then it bubbles up in the DOM tree looking for other ancestor elements with registered event handlers. This phenomenon is known as Event bubbling, and it's a core part of the W3C event model.
data:image/s3,"s3://crabby-images/aa4c3/aa4c36b5eaf26becab20ecc4c12fb237623403fc" alt="appendnode elements of programming interviews appendnode elements of programming interviews"
The answer is element2 is clicked, followed by element1 is clicked. What do you think will be the output when you click element2? 🤔 Enter fullscreen mode Exit fullscreen mode
data:image/s3,"s3://crabby-images/b5c57/b5c578d27f14297d3e252cc580203d8d94169e24" alt="Appendnode elements of programming interviews"