⊗jsSpOtEH 280 of 294 menu

জাভাস্ক্রিপ্টে ইভেন্ট হ্যান্ডলার অপ্টিমাইজেশন

উপাদানের উপর লাগানো অত্যধিক সংখ্যক হ্যান্ডলার অপারেটিভ মেমরি的大量 খায় এবং পৃষ্ঠাকে হ্যাং করতে পারে।

আসুন একটি উদাহরণ দেখি। ধরুন আমাদের একটি তালিকা আছে:

<ul></ul>

একটি ভেরিয়েবলে এই তালিকাটির রেফারেন্স নেওয়া যাক:

let ul = document.querySelector('ul');

এখন আমাদের তালিকাটিকে li ট্যাগ দিয়ে পূরণ করা যাক, এবং তাদের উপর ক্লিক হ্যান্ডলার যোগ করি:

for (let i = 1; i <= 1000; i++) { let li = document.createElement('li'); li.textContent = i; ul.append(li); li.addEventListener('click', function() { console.log(this.textContent); }); }

ফলে দেখা যাচ্ছে যে আমাদের কাছে 1000 হ্যান্ডলার আছে। এটি খুব বেশি। অপ্টিমাইজেশনের জন্য আমরা ul ট্যাগে শুধুমাত্র একটি হ্যান্ডলার যোগ করতে পারি, ডেলিগেশন ব্যবহার করে।

আসুন এটি করা যাক। প্রথমে শুধু তালিকার আইটেম তৈরি করি:

for (let i = 1; i <= 1000; i++) { let li = document.createElement('li'); li.textContent = i; ul.append(li); }

এবং এখন ইভেন্ট হ্যান্ডলারের ডেলিগেশন সম্পন্ন করি:

ul.addEventListener('click', function(event) { let li = event.target.closest('li'); if (li) { console.log(li.textContent); } });

100 বাই 100 আকারের একটি HTML টেবিল তৈরি করুন। এটি এমনভাবে তৈরি করুন যাতে প্রতিটি সেল ক্লিক করলে লাল রং হয়।

বাংলা
AfrikaansAzərbaycanБългарскиБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
আমরা সাইট পরিচালনা, বিশ্লেষণ এবং ব্যক্তিগতকরণের জন্য কুকি ব্যবহার করি। ডেটা প্রক্রিয়াকরণ গোপনীয়তা নীতি অনুযায়ী করা হয়।
সব গ্রহণ করুন কনফিগার করুন প্রত্যাখ্যান করুন