⊗jsPmTrSB 449 of 505 menu

জাভাস্ক্রিপ্টে টাইমার শুরু এবং বন্ধ করার বাটন

এখন চলুন দুটি বাটন তৈরি করি: প্রথমটিতে ক্লিক করলে টাইমার শুরু হোক, আর দ্বিতীয়টিতে ক্লিক করলে বন্ধ হোক। এখানে সবকিছু এত সহজ হবে না এবং আমাদের জন্য একটি সমস্যা লুকিয়ে আছে। এই সমস্যাটির সারবস্তু বোঝার জন্য, আমি ধাপে ধাপে কোড তৈরি করব।

সুতরাং, দুটি বাটন তৈরি করা যাক:

<button id="start">start</button> <button id="stop">stop</button>

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

let start = document.querySelector('#start'); let stop = document.querySelector('#stop');

প্রথম বাটনে ক্লিক করলে টাইমার শুরু করব, এর আইডি একটি ভেরিয়েবলে সংরক্ষণ করে:

start.addEventListener('click', function() { let timerId = setInterval(function() { console.log('!') }, 1000); });

এবং এখন দ্বিতীয় বাটনে ক্লিক করলে টাইমার বন্ধ করব:

start.addEventListener('click', function() { let timerId = setInterval(function() { console.log('!') }, 1000); }); // টাইমার বন্ধ করা হচ্ছে: stop.addEventListener('click', function() { clearInterval(timerId); });

যাইহোক, উপরের কোড চালানোর চেষ্টা করলে আমাদের একটি বিস্ময়ের সম্মুখীন হতে হবে: টাইমার বন্ধ করার চেষ্টা করলে দেখা যাবে যে timerId ভেরিয়েবলটি undefined! কেন এমন হলো? কারণ টাইমার শুরু করার সময় আমরা আমাদের timerId ভেরিয়েবলটিকে start বাটনের সাথে সংযুক্ত ফাংশনের ভিতরে লোকাল করে ফেলেছি।

সমস্যার সমাধানের জন্য timerId ভেরিয়েবলটিকে গ্লোবাল করা যাক - এই ক্ষেত্রে এটি টাইমার শুরু করার ফাংশন এবং বন্ধ করার ফাংশন উভয় থেকেই অ্যাক্সেস করা যাবে:

let timerId; // ভেরিয়েবলটিকে গ্লোবাল করা হল start.addEventListener('click', function() { timerId = setInterval(function() { console.log('!') }, 1000); }); stop.addEventListener('click', function() { clearInterval(timerId); });

ধরুন একটি ভেরিয়েবল দেওয়া আছে, যাতে শুরুতে 100 সংখ্যাটি সংরক্ষিত আছে। আরও দুটি বাটন দেওয়া আছে। প্রথম বাটনে ক্লিক করলে একটি টাইমার শুরু হোক, যা প্রতি সেকেন্ডে ভেরিয়েবলের মান 1 করে কমাবে এবং নতুন মান কনসোলে প্রিন্ট করবে। ভেরিয়েবলের মান শূন্যে পৌঁছামাত্র টাইমারটি বন্ধ হয়ে যাবে।

দ্বিতীয় বাটনে ক্লিক করলে টাইমারটি বন্ধ করুন। এছাড়াও টাইমারটি বন্ধ করুন, যদি দ্বিতীয় বাটন ক্লিক করা না হয়, কিন্তু ভেরিয়েবলের মান শূন্যে পৌঁছে যায়।

একজন প্রোগ্রামার একটি কোড লিখেছেন, যা একটি বাটনে ক্লিক করলে একটি টাইমার শুরু হয়, এবং বর্তমান সময় কনসোলে প্রিন্ট করে:

<input type="submit" id="start" value="start"> <input type="submit" id="stop" value="stop"> let start = document.querySelector('#start'); let stop = document.querySelector('#stop'); start.addEventListener('click', function() { let timerId = setInterval(function() { let date = new Date; console.log(date.getMinutes() + ' ' + date.getSeconds()); }, 1000); }); stop.addEventListener('click', function() { clearInterval(timerId); });

কোড চালানোর পরে, যাইহোক, দেখা গেল যে স্টপ বাটনটি কাজ করছে না। কোড লেখকের ভুলটি সংশোধন করুন।

আরেকজন প্রোগ্রামারও আগের সমস্যার সমাধান করতে কোড লিখেছেন:

<input type="submit" id="start" value="start"> <input type="submit" id="stop" value="stop"> let start = document.querySelector('#start'); let stop = document.querySelector('#stop'); let timerId; start.addEventListener('click', function() { let timerId = setInterval(function() { let date = new Date; console.log(date.getMinutes() + ' ' + date.getSeconds()); }, 1000); }); stop.addEventListener('click', function() { clearInterval(timerId); });

কোড চালানোর পরে, যাইহোক, আবার দেখা গেল, যে স্টপ বাটনটি কাজ করছে না। কোড লেখকের ভুলটি সংশোধন করুন।

আরেকজন প্রোগ্রামারও আগের সমস্যার সমাধান করতে কোড লিখেছেন:

<input type="submit" id="start" value="start"> <input type="submit" id="stop" value="stop"> let start = document.querySelector('start'); let stop = document.querySelector('stop'); let timerId; start.addEventListener('click', function() { setInterval(function() { let date = new Date; console.log(date.getMinutes() + ' ' + date.getSeconds()); }, 1000); }); stop.addEventListener('click', function() { clearInterval(timerId); });

কোড চালানোর পরে, যাইহোক, আবার দেখা গেল, যে স্টপ বাটনটি কাজ করছে না। কোড লেখকের ভুলটি সংশোধন করুন।

আরেকজন প্রোগ্রামারও আগের সমস্যার সমাধান করতে কোড লিখেছেন:

<input type="submit" id="start" value="start"> <input type="submit" id="stop" value="stop"> let start = document.querySelector('start'); let stop = document.querySelector('stop'); let timerId; start.addEventListener('click', function() { let timerId = setInterval(function() { let date = new Date; console.log(date.getMinutes() + ' ' + date.getSeconds()); }, 1000); }); stop.addEventListener('click', function() { clearInterval(); });

কোড চালানোর পরে, যাইহোক, আবার দেখা গেল, যে স্টপ বাটনটি কাজ করছে না। কোড লেখকের ভুলটি সংশোধন করুন।

তাত্ত্বিক অংশে আমি দেওয়া কোডটি এই বিষয়টি বিবেচনা করে না যে স্টার্ট বাটনে একাধিকবার ক্লিক করা যেতে পারে। এই সমস্যা সমাধানের জন্য স্টার্ট বাটনে ক্লিক করলে ইভেন্টটি এই বাটন থেকে আনবাইন্ড করা যেতে পারে, আর স্টপ বাটনে ক্লিক করলে - আবার বাইন্ড করা যেতে পারে। সমস্যাটি সংশোধন করুন।

বাংলা
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
আমরা সাইট পরিচালনা, বিশ্লেষণ এবং ব্যক্তিগতকরণের জন্য কুকি ব্যবহার করি। ডেটা প্রক্রিয়াকরণ গোপনীয়তা নীতি অনুযায়ী করা হয়।
সব গ্রহণ করুন কনফিগার করুন প্রত্যাখ্যান করুন