Hi everyone! I'm the author of code.mu :)
I'd love to chat with my non-Russian audience. I'm looking for your feedback on the site and the translation quality. Let's chat:)
15 of 17 menu

জাভাস্ক্রিপ্টে ক্যালেন্ডার সুইচ করার ত্রুটি

ধরুন আমরা ক্যালেন্ডার সুইচ করার জন্য তীরচিহ্ন বোতাম তৈরি করতে চাই। এই ক্ষেত্রে বেশ কয়েকটি সাধারণ ত্রুটি করা সম্ভব। আসুন সেগুলি দেখে নেওয়া যাক।

ধরুন আমাদের কাছে সুইচ বোতাম এবং একটি এলিমেন্ট আছে, যেখানে আমরা সরলতার জন্য ক্যালেন্ডার প্রদর্শন করব না, বরং শুধুমাত্র বছর এবং মাসের নাম 출력 করব:

<button id="prev">prev</button> <div id="elem"></div> <button id="next">next</button>

আমাদের এলিমেন্টগুলির রেফারেন্স নেওয়া যাক:

let elem = document.querySelector('#elem'); let prev = document.querySelector('#prev'); let next = document.querySelector('#next');

ধরুন আমাদের কাছে একটি ফাংশনও আছে, যা প্যারামিটার হিসাবে মাস নম্বর নেয় এবং এর নাম রিটার্ন করে:

function getMonthName(month) { let names = [ 'জানু', 'ফেব্রু', 'মার্চ', 'এপ্রিল', 'মে', 'জুন', 'জুলাই', 'আগস্ট', 'সেপ্টেম্বর', 'অক্টোবর', 'নভেম্বর', 'ডিসেম্বর' ]; return names[month]; }

পৃষ্ঠা লোড হওয়ার পর বর্তমান বছর এবং মাস নেওয়া যাক:

let date = new Date; let year = date.getFullYear(); let month = date.getMonth();

আমাদের এলিমেন্টে বছর এবং মাসের নাম আউটপুট করি (ক্যালেন্ডারের অনুকরণ):

elem.textContent = year + ' ' + getMonthName(month);

এবার ক্লিক হ্যান্ডলারগুলি সুইচারগুলিতে সংযুক্ত করা যাক:

prev.addEventListener('click', function() { // পূর্ববর্তী মাস দেখানো হচ্ছে }); next.addEventListener('click', function() { // পরবর্তী মাস দেখানো হচ্ছে });

এখন সুইচারগুলি বাস্তবায়ন করার সময় কোন ত্রুটিগুলি করা যেতে পারে তা বিবেচনা করা যাক।

প্রথম ত্রুটি

ধরুন একজন প্রোগ্রামার মাস সুইচ করার বোতামগুলি এইভাবে বাস্তবায়ন করেছেন:

next.addEventListener('click', function() { elem.textContent = year + ' ' + getMonthName(month + 1); }); prev.addEventListener('click', function() { elem.textContent = year + ' ' + getMonthName(month - 1); });

যাইহোক, এই প্রোগ্রামার একটি ত্রুটি করেছেন, যার কারণে শুধুমাত্র প্রথম ক্লিকে মাস পরিবর্তন হয়, পরবর্তী ক্লিকগুলিতে হয় না।

ব্যাপারটি হল month ভেরিয়েবলটি ফাংশনের ভিতরে পরিবর্তিত হয় না - এটির বিষয়বস্তুর সাথে শুধু এক যোগ করা হয় এবং ফলাফল getMonthName ফাংশনে পাঠানো হয়।

যেহেতু আমাদের ভেরিয়েবল পরিবর্তিত হয়নি, পরবর্তী ক্লিকেও এতে আগের মতোই বর্তমান মাস থাকবে - এবং কিছুই পরিবর্তন হবে না।

সমস্যাটি ঠিক করা যাক:

next.addEventListener('click', function() { month = month + 1; elem.textContent = year + ' ' + getMonthName(month); }); prev.addEventListener('click', function() { month = month - 1; elem.textContent = year + ' ' + getMonthName(month); });

সরলীকরণ করা যেতে পারে:

next.addEventListener('click', function() { elem.textContent = year + ' ' + getMonthName(++month); }); prev.addEventListener('click', function() { elem.textContent = year + ' ' + getMonthName(--month); });

দ্বিতীয় ত্রুটি

প্রায়শই এটি ভুলে যায় যে মাস একটি নির্দিষ্ট সীমার মধ্যে পরিবর্তন হওয়া উচিত - 0 থেকে 11 পর্যন্ত। সীমায় পৌঁছানোর সময় আমাদের বছর পরিবর্তন করতে হবে (সামনে বা পিছনে), এবং মাস প্রারম্ভিক মানে রিসেট করতে হবে।

এটি করা যাক:

next.addEventListener('click', function() { if (month === 11) { month = 0; year++; } else { month++; } elem.textContent = year + ' ' + getMonthName(month); }); prev.addEventListener('click', function() { if (month === 0) { month = 11; year--; } else { month--; } elem.textContent = year + ' ' + getMonthName(month); });
বাংলা
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
আমরা সাইট পরিচালনা, বিশ্লেষণ এবং ব্যক্তিগতকরণের জন্য কুকি ব্যবহার করি। ডেটা প্রক্রিয়াকরণ গোপনীয়তা নীতি অনুযায়ী করা হয়।
সব গ্রহণ করুন কনফিগার করুন প্রত্যাখ্যান করুন