Math Quiz Game
Video
Here’s a detailed explanation of the enhanced Math Quiz Game code: HTML Structure Dropdown for Operation Selection: html Copy code Provides four math operation options: Addition, Subtraction, Multiplication, and Division. The selected option determines the type of math problems generated. Start Quiz Button: html Copy code Calls the generateQuestions() function to create 10 random math questions based on the selected operation. Quiz Container: html Copy code
A placeholder where 10 questions (with inputs for answers) are dynamically added. Submit Answers Button: html Copy code Initially hidden. After the quiz is generated, it becomes visible. Clicking it evaluates the user’s answers and displays their score. Results Display: html Copy code Displays the user’s score after the answers are submitted. CSS Styles Visual Feedback: correct: Green border and light green background for correct answers. wrong: Red border and light red background for incorrect answers. css Copy code .correct { border: 2px solid green; background-color: #e6ffe6; } .wrong { border: 2px solid red; background-color: #ffe6e6; } Error Display: css Copy code .correct-answer { font-size: 14px; color: red; } Displays the correct answer below the input field if the user’s answer is incorrect. JavaScript Logic The JavaScript code is divided into three main functionalities: 1. Generating Questions The generateQuestions() function dynamically creates 10 questions based on the selected operation. javascript Copy code function generateQuestions() { const operation = document.getElementById('operation').value; // Get selected operation questions = []; // Clear any previous questions const quizContainer = document.getElementById('quiz-container'); quizContainer.innerHTML = ''; // Clear previous questions For Each Question: Random numbers (num1 and num2) are generated depending on the operation. The correct answer is calculated and stored in the questions array. Example for Different Operations: Addition: javascript Copy code num1 = getRandomNumber(10, 999); num2 = getRandomNumber(10, 999); answer = num1 + num2; questionText = `${num1} + ${num2} = `; Subtraction: javascript Copy code num1 = getRandomNumber(10, 999); num2 = getRandomNumber(10, num1); // Ensure num1 >= num2 answer = num1 - num2; questionText = `${num1} - ${num2} = `; Multiplication: javascript Copy code num1 = getRandomNumber(2, 99); num2 = getRandomNumber(2, 99); answer = num1 * num2; questionText = `${num1} × ${num2} = `; Division: javascript Copy code num2 = getRandomNumber(2, 20); answer = getRandomNumber(2, 50); num1 = num2 * answer; // Ensure num1 is divisible by num2 questionText = `${num1} ÷ ${num2} = `; Dynamically Add Questions to the Page: javascript Copy code const questionDiv = document.createElement('div'); questionDiv.className = 'question'; questionDiv.innerHTML = ` ${i + 1}. ${questionText} `; quizContainer.appendChild(questionDiv); For each question: A div is created containing the question text and an input box for the user’s answer. A hidden span (correct-answer) is added to display the correct answer if needed. 2. Random Number Generation The getRandomNumber() function generates random numbers between a specified range. javascript Copy code function getRandomNumber(min, max) { return Math.floor(Math.random() * (max - min + 1)) + min; } 3. Calculating the Score The calculateScore() function evaluates the user’s answers. For Each Question: javascript Copy code const inputField = document.getElementById(`answer-${index}`); const userAnswer = parseFloat(inputField.value); const correctAnswerSpan = document.getElementById(`correct-answer-${index}`); Check If the User’s Answer Is Correct: If correct: javascript Copy code score++; inputField.classList.add('correct'); inputField.classList.remove('wrong'); correctAnswerSpan.style.display = 'none'; Add the correct class for visual feedback. If incorrect: javascript Copy code inputField.classList.add('wrong'); inputField.classList.remove('correct'); correctAnswerSpan.textContent = `(Correct Answer: ${q.answer})`; correctAnswerSpan.style.display = 'inline'; Add the wrong class and display the correct answer. Display Final Score: javascript Copy code document.getElementById('result').textContent = `You scored ${score} out of ${numQuestions}!`; How the Game Works Step 1: Select an Operation: The user selects an operation (e.g., Addition) from the dropdown. Step 2: Generate Questions: Click Start Quiz to dynamically generate 10 math questions. Step 3: Answer the Questions: The user enters their answers in the provided input boxes. Step 4: Submit Answers: Clicking Submit Answers evaluates the user’s responses. Correct answers highlight the box in green. Incorrect answers highlight the box in red and display the correct answer. Step 5: View Results: The total score is displayed at the bottom. Key Improvements Dropdown for Operations: User flexibility to select Addition, Subtraction, Multiplication, or Division. Dynamic Feedback: Correct answers: Green highlight. Incorrect answers: Red highlight with correct answer displayed. Randomized Question Generation: Questions are unique and tailored to the selected operation. Division Questions: Ensures no fractional answers by generating divisible numbers. This makes the game interactive, educational, and user-friendly. Let me know if you have more questions!
No comments:
Post a Comment