Menu
3.8. Event capturing এবং bubbling এর পার্থক্য
DOM ইভেন্টগুলি ইভেন্ট প্রোপাগেশন 3টি পর্যায় বর্ণনা করে: ক্যাপচারিং ফেজ – ইভেন্টটি এলিমেন্ট চলে যায়। টার্গেট ফেজ – ইভেন্ট টার্গেট এলিমেন্টে পৌঁছেছে। বাবলিং পর্যায় – ঘটনাটি এলিমেন্ট থেকে উঠে। ইভেন্ট বাবলিং হলো ইভেন্ট-এর প্রোপাগেশন যেটা এর অরিজিন থেকে উপরে রুট ইলিমেন্ট পর্যন্ত গিয়ে থামে। অর্থাং যখনি কোনো একজন ইউজার পেজের কোনো একটা বাটনে ক্লিক করে তথন সেই বাটনের আন্ডারে যে ইভেন্ট হ্যান্ডেলার টা আছে সেই ইভেন্ট টা তার প্যারেন্ট, তার প্যারেন্ট, আবার তার প্যারেন্ট এভাবে সে রুট ইলিমেন্ট Html পর্যন্ত ইভেন্ট-এর প্রোপাগেশন বা প্রচার চালায় । ইভেন্ট টি তার উপরের সব ইলিমেন্ট কে জানিয়ে দেয় যে, কেউ একজন তাকে ক্লিক করেছে। আপনি চাইলে বাবলিং টাকে রোধ করতে পারেন, জাস্ট stopPropagation মেথড ব্যবহার করে।document.querySelector(‘#signin’).addEventListener(‘click’, (e) => {
e.stopPropagation();
console.log(‘Sign in button click’);
});
We already know the basics of event capturing and bubbling.
<!DOCTYPE html><html lang=“en”><head><meta charset=“UTF-8”><meta http-equiv=“X-UA-Compatible” content=“IE=edge”><meta name=“viewport” content=“width=device-width, initial-scale=1.0”><title>Event Bubbling and Capturing</title><!– Some css to identify the divs easily –><style>div {border: 1px solid black;}#grandparent {background-color: green;width: 300px;height: 300px;}#parent {background-color: blue;width: 200px;height: 200px;}#child {background-color: red;width: 100px;height: 100px;}</style></head><body><div id=“grandparent”>Grandparent<div id=“parent”>Parent<div id=“child”>Child</div></div></div></body></html>In this example, we will dive a little deeper. The third argument of ‘addEventListener’ function tell whether the event will be in the capture phase or in the bubbling phase. By default it is in bubbling phase (if we provide no parameter)const grandparent = document.getElementById(“grandparent”) const parent = document.getElementById(“parent”) const child = document.getElementById(“child”) // bubbling grandparent.addEventListener(“click”, ()=> { console.log(“Grandparent clicked”); }, false) // capturing or trickling parent.addEventListener(“click”, ()=> { console.log(“Parent clicked”); }, true) // bubbling child.addEventListener(“click”, ()=> { console.log(“Child clicked”); }, false)Run the code. now click on the child div. We can see that the output will be.Output:Parent clickedChild clickedGrandparent clickedWe can stop event capturing and bubbling if we want.We can use a parameter “e” in the callback function ofaddEventListener function. It is an event objectwhich has a function called stopPropagation() which helpsto stop event capturing and bubbling.<!DOCTYPE html><html lang=“en”><head><meta charset=“UTF-8”><meta http-equiv=“X-UA-Compatible” content=“IE=edge”><meta name=“viewport” content=“width=device-width, initial-scale=1.0”><title>How to stop Event Capturing and Bubbling</title><!– Some css to identify the divs easily —><style>div {border: 1px solid black;}#grandparent {background-color: green;width: 300px;height: 300px;}#parent {background-color: blue;width: 200px;height: 200px;}#child {background-color: red;width: 100px;height: 100px;}</style></head><body><div id=“grandparent”>Grandparent<div id=“parent”>Parent<div id=“child”>Child</div></div></div></body></html>const grandparent = document.getElementById(“grandparent”)const parent = document.getElementById(“parent”)const child = document.getElementById(“child”)// bubblinggrandparent.addEventListener(“click”, (e)=> {console.log(“Grandparent clicked”);})// bubblingparent.addEventListener(“click”, (e)=> {console.log(“Parent clicked”);e.stopPropagation()})// bubblingchild.addEventListener(“click”, (e)=> {console.log(“Child clicked”);})Output:Child clickedParent clickedইফেক্ট বুঝতে হলে প্রথমে এই HTML ফাইলটি আপনার ব্রাউজারে ওপেন করে মাউসের রাইট বাটন ক্লিক করে Inspect এ ক্লিক করুন। অতঃপর Console ট্যাবে ক্লিক করুন। এখন Event Bubbling ও Event Capturing কিভাবে হচ্ছে সেটা বুঝতে বক্সগুলোতে ক্লিক করে দেখুন।
<!DOCTYPE html><html lang=“en”><head><meta charset=“UTF-8”><meta http-equiv=“X-UA-Compatible” content=“IE=edge”><meta name=“viewport” content=“width=device-width, initial-scale=1.0”><title>Event Bubbling and Capturing</title><!– CSS Style for Better Visualization —><style>body {height: 100vh;}h2 { text-align: center; }.mid {display: flex;justify-content: space-around;align-items: center;cursor: pointer;}.hw300 {height: 300px;width: 300px;}.hw200 {height: 200px;width: 200px;}.hw100 {height: 100px;width: 100px;}#red { background-color: red; }#green { background-color: green; }#skyblue { background-color: skyblue; }#blue { background-color: blue; }#purple { background-color: purple; }#gold { background-color: goldenrod; }</style></head><body class=“mid” style=“cursor: auto;”><!– Event Bubbling Section —><h2>Event Bubbling<div id=“red” class=“mid hw300”><div id=“green” class=“mid hw200”><div id=“skyblue” class=“mid hw100”>Click Me</div></div></div></h2><!– Event Capturing Section —><h2>Event Capturing<div id=“blue” class=“mid hw300”><div id=“purple” class=“mid hw200”><div id=“gold” class=“mid hw100”>Click Me</div></div></div></h2></body></html>const redDiv = document.querySelector(‘#red’);const greenDiv = document.querySelector(‘#green’);const skyblueDiv = document.querySelector(‘#skyblue’);const blueDiv = document.querySelector(‘#blue’);const purpleDiv = document.querySelector(‘#purple’);const goldDiv = document.querySelector(‘#gold’);// Event Bubbling PhaseredDiv.addEventListener(‘click’, () => {console.log(‘Red box clicked.’);}, false)greenDiv.addEventListener(‘click’, () => {console.log(‘Green box clicked’);}, false)skyblueDiv.addEventListener(‘click’, () => {console.log(‘Skyblue box clicked’);}, false)// Event Capturing PhaseblueDiv.addEventListener(‘click’, () => {console.log(‘Blue box clicked.’);}, true)purpleDiv.addEventListener(‘click’, () => {console.log(‘Purple box clicked’);}, true)goldDiv.addEventListener(‘click’, () => {console.log(‘Golden box clicked’);}, true)addEventListener() ফাংশনের তৃতীয় argument হিসেবে আমরা যে true/false ভ্যালু দিয়েছি সেটা বাই ডিফল্ট false থাকে অর্থাৎ nested element ক্লিক করার ক্ষেত্রে সেটা বাই ডিফল্ট event bubbling করে থাকে। বিষয়টি যদি অন্যভাবে বলি তাহলে বলা যায় যে তৃতীয় আর্গুমেন্টে জিজ্ঞাসা করা থাকে এই event টি প্রথমে capture করা হবে নাকি হবে না।
1. What is event bubbling and capturing?
2. What is event bubbling for?
3. What is event propagation in DOM?
4. Why do we use event bubbling?
5. How can you stop the event bubbling up?