LoginSignup
1
0

Bingo

Last updated at Posted at 2024-01-28

はじめに

今回はBingoとかに使うマシーンについて紹介していこうと思います。と思います。
Bingoマシーンを利用するときに思ったことは

  • HTML,CSS,jsを分けたほうがわかりやすい、
    僕のおすすめはやはり上の分けるやつですかね。

プログラム

html

<!-- index.html -->
<!DOCTYPE html>
<html lang="ja">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Bingoマシーン</title>
    <link rel="stylesheet" href="style.css">
</head>
<body>
    <div class="container">
        <div id="bingoNumber" onclick="generateRandomNumber()">Tap for Bingo!</div>

        <div id="numberList">選ばれた数字: </div>
    </div>

    <script src="script.js"></script>
</body>
</html>

CSS

/* style.css */
body {
    margin: 0;
    font-family: Arial, sans-serif;
    background-color: #f8f8f8;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100vh;
}

.container {
    text-align: center;
    background-color: #fff;
    padding: 20px;
    border-radius: 10px;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
}

#bingoNumber {
    font-size: 48px;
    padding: 20px;
    border: 2px solid #333;
    cursor: pointer;
    user-select: none;
    transition: transform 0.1s ease-in-out;
    margin-bottom: 20px;
}

#bingoNumber:hover {
    transform: scale(1.1);
}

#numberList {
    font-size: 18px;
    margin-top: 20px;
}

js

// script.js
let selectedNumbers = [];

function generateRandomNumber() {
    const bingoNumberElement = document.getElementById('bingoNumber');
    const numberListElement = document.getElementById('numberList');

    // タップごとにランダムな数字表示
    const minNumber = 1;
    const maxNumber = 100;

    // 未出の数字を抽選する
    let number;
    do {
        number = Math.floor(Math.random() * (maxNumber - minNumber + 1)) + minNumber;
    } while (selectedNumbers.includes(number));

    // ドキドキ感を演出するアニメーション
    bingoNumberElement.style.transform = 'scale(1.1)';
    setTimeout(() => {
        bingoNumberElement.style.transform = 'scale(1)';
    }, 100);

    // ビンゴマシンに表示
    bingoNumberElement.innerText = number;

    // 選ばれた数字をリストに追加
    selectedNumbers.push(number);

    // 選ばれた数字のリストを更新
    updateNumberList();
}

function updateNumberList() {
    const numberListElement = document.getElementById('numberList');
    numberListElement.innerHTML = '選ばれた数字: ' + selectedNumbers.join(', ');
}

ちなみに上の

const minNunber=1;
const maxNumber=100;

のところで最低値と最大値を設定します。
CSSはしっかりと模様をつけているだけです。
jsでは表示するところをやっています。

最後に

このBINGOに付け足したいものがあったらコメント欄によろしくお願いいたします。

1
0
3

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
0