মাহা নামে একজন শিক্ষিকা তার ছাত্রছাত্রীদের জন্য একটি ছোট শিক্ষামূলক গেম তৈরি করতে চেয়েছিলেন, যেখানে তারা গাণিতিক প্রশ্নের সমস্যাগুলোর উত্তর দিতে পারবে এবং প্রতিটি সঠিক উত্তরের জন্য পয়েন্ট পাবে। এই গেমটি তৈরি করতে মাহাকে জাভাস্ক্রিপ্ট শিখতে হলো। দেখা যাক কিভাবে সে জাভাস্ক্রিপ্টের বিভিন্ন বিষয় শিখে গেমটি তৈরি করলো।
ভেরিয়েবল
মাহা প্রথমেই বুঝতে পারলো তাকে পয়েন্টস এবং প্রশ্ন এর মতো কিছু ডেটা সংরক্ষণ করতে হবে। এজন্য সে let এবং const ভেরিয়েবল দিয়ে কাজ শুরু করলো। const দিয়ে সে গেমের নাম ও স্ট্যাটিক ডেটা সংরক্ষণ করলো, আর let দিয়ে পয়েন্টস সংরক্ষণ করলো যা গেমের সময় পরিবর্তিত হবে।
const gameName = "Math Quiz";
let points = 0;
ডাটা টাইপস
এরপর, মাহা বুঝতে পারলো যে তাকে বিভিন্ন ধরনের ডেটা টাইপ শিখতে হবে। যেমনঃ প্রশ্নগুলো স্ট্রিং টাইপের হবে, সঠিক উত্তর নাম্বার টাইপের, আর যদি উত্তর সঠিক হয় তবে সেটা বুলিয়ান হতে পারে।
let question = "What is 5 + 3?";
let correctAnswer = 8;
let isCorrect = false;
অপারেটরস
গেমের গাণিতিক সমস্যাগুলো তৈরিতে মাহা অপারেটর ব্যবহার করতে শিখলো। + (অ্যাডিশন), - (সাবট্রাকশন), * (মাল্টিপ্লিকেশন), / (ডিভিশন) অপারেটর দিয়ে সে বিভিন্ন গণনা সংক্রান্ত সমস্যা তৈরির উপায় শিখলো। এ ছাড়া, === (ইকুয়্যাল ভ্যালু এবং ইকুয়্যাল টাইপ) ব্যবহার করে ছাত্রছাত্রীদের দেওয়া উত্তর সঠিক কিনা তা যাচাই করতে শিখলো।
let userAnswer = 8;
isCorrect = userAnswer === correctAnswer;
কন্ডিশনাল স্টেটমেন্ট
গেমে উত্তর সঠিক হলে পয়েন্ট বাড়ানোর জন্য মাহা if...else স্টেটমেন্ট ব্যবহার শিখলো। যদি উত্তর সঠিক হয়, তাহলে পয়েন্ট বাড়বে, আর না হলে সে বলবে "ভুল উত্তর।"
if (isCorrect) {
points += 10;
console.log("Correct! Points: " + points);
} else {
console.log("Incorrect answer. Try again!");
}
লুপস
গেমটি যেন কয়েকটি প্রশ্ন পর্যন্ত চলতে পারে, এজন্য সে for লুপ ব্যবহার করলো। এটি গেমে একই প্রক্রিয়া বারবার চালাতে সাহায্য করলো।
for (let i = 0; i < 5; i++) {
// প্রশ্ন তৈরি ও উত্তর যাচাইয়ের কোড
}
ফাংশনস
গাণিতিক প্রশ্ন তৈরি ও উত্তর যাচাইয়ের জন্য মাহা ফাংশন শিখে নিলো। সে একটি generateQuestion() ফাংশন তৈরি করলো যা দিয়ে প্রশ্ন তৈরি করবে, এবং একটি checkAnswer() ফাংশন তৈরি করলো যা দিয়ে সঠিক উত্তর যাচাই করবে।
function generateQuestion() {
// র্যান্ডম প্রশ্ন তৈরি
}
function checkAnswer(userAnswer, correctAnswer) {
return userAnswer === correctAnswer;
}
DOM ম্যানিপুলেশন এবং ইভেন্ট হ্যান্ডলিং
মাহাকে গেমের জন্য একটা ব্যবহারকারী ইন্টারফেসও তৈরি করতে হলো। DOM ম্যানিপুলেশন দিয়ে সে প্রশ্ন ও উত্তরের অংশগুলো HTML এর সাথে যুক্ত করলো। এরপর, যখন ছাত্রছাত্রীরা উত্তর দিবে তখন ইভেন্ট হ্যান্ডলিং ব্যবহার করে সে ব্যবহারকারীর ইন্টারঅ্যাকশন ক্যাপচার করলো।
document.getElementById("submitAnswer").addEventListener("click", function () {
let userAnswer = parseInt(document.getElementById("userInput").value);
if (checkAnswer(userAnswer, correctAnswer)) {
points += 10;
alert("Correct!");
} else {
alert("Incorrect, try again.");
}
});
এভাবে, মাহা জাভাস্ক্রিপ্টের প্রতিটি গুরুত্বপূর্ণ
কনসেপ্ট শেখার মাধ্যমে তার শিক্ষার্থীদের জন্য গেমটি তৈরি করতে সক্ষম হলো। এতে শুধু
তার নিজের প্রোগ্রামিং জ্ঞান বাড়ল না, তার ছাত্রছাত্রীরাও শিক্ষার মাধ্যমে আনন্দ পেল
এবং কিভাবে একটি সমস্যা থেকে জাভাস্ক্রিপ্টের মাধ্যমে সমাধান করতে হয় তা শিখিয়ে দিল।
নিচে জাভাস্ক্রিপ্টে ব্যবহৃত কিছু গুরুত্বপূর্ণ
বিষয় একটি টেবিল আকারে দেওয়া হলো:
বিষয় |
ব্যবহার |
ভেরিয়েবল (Variables) |
ডেটা
সংরক্ষণের জন্য ব্যবহার করা হয়। |
ডাটা টাইপস (Data Types) |
ভিন্ন
ভিন্ন ধরন (স্ট্রিং, নাম্বার) সংরক্ষণের জন্য ব্যবহার করা হয়। |
অপারেটরস (Operators) |
গণনা,
তুলনা, এবং লজিক্যাল অপারেশনের জন্য ব্যবহার করা হয়। |
কন্ডিশনাল স্টেটমেন্টস
(Conditional Statements) |
নির্দিষ্ট
শর্তের ভিত্তিতে কার্য চালাতে ব্যবহার করা হয়। |
লুপস (Loops) |
বারবার
কোনো কার্য সম্পাদনের জন্য ব্যবহার করা হয়। |
ফাংশনস (Functions) |
পুনরাবৃত্তিমূলক
কাজগুলোকে সংরক্ষণের জন্য ব্যবহার করা হয়। |
অবজেক্টস (Objects) |
ডেটা
ও ফাংশনগুলোকে একটি ইউনিটে সংরক্ষণ এবং জটিল ডেটা কাঠামো তৈরি করার জন্য ব্যবহার
করা হয়। |
অ্যারেস (Arrays) |
একাধিক
আইটেম একসাথে সংরক্ষণ করতে ব্যবহার করা হয়। |
DOM ম্যানিপুলেশন (DOM
Manipulation) |
HTML
ও CSS পরিবর্তন এবং ব্যবহারকারী ইন্টারফেস আপডেট ও ইন্টারঅ্যাকশনের জন্য ব্যবহার
করা হয়। । |
ইভেন্ট হ্যান্ডলিং (Event
Handling) |
ব্যবহারকারী
ইন্টারঅ্যাকশন পরিচালনা করতে ব্যবহার করা হয়। |
ES6 ফিচারস (ES6 Features) |
আধুনিক
প্রোগ্রামিং সুবিধা এবং প্রোগ্রামিং আরও কার্যকর ও জটিলতা কমাতে সাহায্য করে। |
“গল্পে গল্পে প্রোগ্রামিং শিখুন” আমাদের ওয়েবসাইটটি
বুকমার্ক করে রাখুন! গল্পটি উপভোগ করলে বন্ধুরা যাতে মিস না করে, সেটি শেয়ার করতে ভুলবেন
না। আর, লাইক ও কমেন্ট করে আমাদের জানাতে ভুলবেন না যেন।