MyProjects/VanillaJS

Number Matcher Game

LeeDaniel 2024. 11. 28. 10:10
<!DOCTYPE html>
<html lang="ko">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Number Matcher</title>
    <style>
        body {
            font-family: Arial, sans-serif;
            display: flex;
            flex-direction: column;
            align-items: center;
            height: 100vh;
            margin: 0;
            background-color: #f5f5f5;
        }

        #header {
            font-size: 24px;
            font-weight: bold;
            margin: 20px 0;
        }

        #container {
            display: flex;
            gap: 20px;
        }

        #game {
            display: flex;
            flex-direction: column;
            align-items: center;
        }

        #numberDisplay {
            width: 200px;
            height: 100px;
            display: flex;
            align-items: center;
            justify-content: center;
            border: 2px solid black;
            background-color: white;
            font-size: 24px;
            font-weight: bold;
            margin-bottom: 20px;
        }

        #result {
            margin-top: 10px;
            font-size: 18px;
        }

        #time {
            margin-top: 5px;
            font-size: 14px;
            color: gray;
        }

        #controls {
            display: flex;
            align-items: center;
            gap: 10px;
        }

        input[type="text"] {
            padding: 5px;
            font-size: 16px;
            width: 150px;
        }

        button {
            padding: 5px 10px;
            font-size: 16px;
            cursor: pointer;
        }

        #history {
            width: 200px;
            height: 300px;
            border: 2px solid black;
            overflow-y: auto;
            padding: 10px;
            background-color: #fff;
            font-size: 14px;
        }

        #historyList li:first-child {
            color: blue;
            font-weight: bold;
        }

        .fastest {
            color: green;
            font-weight: bold;
        }
    </style>
</head>

<body>
    <div id="header">Number Matcher Game</div>
    <div id="container">
        <div id="game">
            <div id="numberDisplay">000000</div>
            <div id="controls">
                <input type="text" id="inputField" placeholder="Enter numbers">
                <button id="checkButton">Check</button>
            </div>
            <div id="result"></div>
            <div id="time"></div>
        </div>
        <div id="history">
            <strong>Completion Times:</strong>
            <ul id="historyList" style="padding: 0; margin: 0; list-style: none;"></ul>
        </div>
    </div>

    <script>
        const numberDisplay = document.getElementById("numberDisplay");
        const inputField = document.getElementById("inputField");
        const checkButton = document.getElementById("checkButton");
        const result = document.getElementById("result");
        const time = document.getElementById("time");
        const historyList = document.getElementById("historyList");

        let randomNumbers = generateRandomNumbers();
        let startTime = Date.now();
        let fastestTime = null;

        function generateRandomNumbers() {
            const numbers = Array.from({ length: 6 }, () => Math.floor(Math.random() * 10));
            numberDisplay.textContent = numbers.join("");
            return numbers.join("");
        }

        function checkMatch() {
            const userInput = inputField.value;
            inputField.value = ""; // Clear input field

            if (userInput === randomNumbers) {
                result.textContent = "Match!";
                result.style.color = "green";

                const elapsedTime = (Date.now() - startTime) / 1000;
                time.textContent = `Time taken: ${elapsedTime.toFixed(2)} seconds`;

                // Add time to history
                const historyItem = document.createElement("li");
                historyItem.textContent = `${elapsedTime.toFixed(2)} seconds`;

                // Check if this is the fastest time
                if (fastestTime === null || elapsedTime < fastestTime) {
                    fastestTime = elapsedTime;
                    Array.from(historyList.children).forEach(item => item.classList.remove("fastest"));
                    historyItem.classList.add("fastest");
                }

                historyList.prepend(historyItem); // Add to the top of the list

                randomNumbers = generateRandomNumbers(); // Generate new random numbers
                startTime = Date.now(); // Reset timer
            } else {
                result.textContent = "No Match";
                result.style.color = "red";
            }
        }

        checkButton.addEventListener("click", checkMatch);
        inputField.addEventListener("keydown", (e) => {
            if (e.key === "Enter") {
                checkMatch();
            }
        });
    </script>
</body>

</html>​













728x90
반응형