一个十字翻转小游戏

有没有万能公式,我现在只会33 35这种简单的

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Toggle Grid Game</title>
    <style>
        body {
            font-family: Arial, sans-serif;
            text-align: center;
            margin: 0;
            padding: 0;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            height: 100vh;
            background-color: #f0f0f0;
        }
        .grid {
            display: grid;
            border: 2px solid red; /* Outer border in red */
            margin-top: 20px;
        }
        .cell {
            width: 30px;
            height: 30px;
            border: 1px solid red; /* Red border for each cell */
            margin: 0;
            padding: 0;
            background-color: white;
            cursor: pointer;
        }
        .cell.black {
            background-color: black;
        }
        .controls {
            margin-bottom: 20px;
        }
        .controls input,
        .controls button {
            margin-right: 10px;
            padding: 5px;
        }
    </style>
</head>
<body>
    <h1>Toggle Grid Game</h1>
    <div class="controls">
        <label for="rows">Rows:</label>
        <input type="number" id="rows" value="3" min="1" max="50">
        <label for="cols">Columns:</label>
        <input type="number" id="cols" value="3" min="1" max="50">
        <button onclick="initializeGrid()">Set Grid</button>
        <button onclick="fillAllBlack()">Fill All Black</button>
    </div>
    <div id="gridContainer"></div>
    <script>
        let rows = 3; // Default number of rows
        let cols = 3; // Default number of columns
        let grid = [];
        let clickCount = 0; // Counter for clicks

        const container = document.getElementById("gridContainer");

        // Function to initialize grid
        function initializeGrid() {
            rows = parseInt(document.getElementById("rows").value, 10);
            cols = parseInt(document.getElementById("cols").value, 10);
            clickCount = 0; // Reset click count

            // Initialize grid with random 0s and 1s
            grid = Array.from({ length: rows }, () => Array.from({ length: cols }, () => Math.random() < 0.5 ? 1 : 0));

            // Set grid layout styles dynamically
            container.style.gridTemplateRows = `repeat(${rows}, 30px)`; // Fixed height for rows
            container.style.gridTemplateColumns = `repeat(${cols}, 30px)`; // Fixed width for columns
            container.classList.add("grid");

            // Render grid
            createGrid();
        }

        // Function to render grid
        function createGrid() {
            container.innerHTML = ""; // Clear existing grid
            grid.forEach((row, rowIndex) => {
                row.forEach((cell, colIndex) => {
                    const button = document.createElement("button");
                    button.className = `cell ${cell ? "black" : ""}`; // Black if 1, white if 0
                    button.onclick = () => toggleCell(rowIndex, colIndex);
                    container.appendChild(button);
                });
            });
            checkWin(); // Check for win condition after rendering
        }

        // Toggle cell and adjacent cells
        function toggleCell(x, y) {
            clickCount++; // Increment click count
            grid[x][y] ^= 1;
            if (x > 0) grid[x - 1][y] ^= 1; // Top
            if (x < rows - 1) grid[x + 1][y] ^= 1; // Bottom
            if (y > 0) grid[x][y - 1] ^= 1; // Left
            if (y < cols - 1) grid[x][y + 1] ^= 1; // Right
            createGrid(); // Re-render the grid
        }

        // Fill all cells with black
        function fillAllBlack() {
            grid = Array.from({ length: rows }, () => Array.from({ length: cols }, () => 1)); // All 1s
            clickCount = 0; // Reset click count
            createGrid(); // Re-render the grid
        }

        // Check if all cells are white
        function checkWin() {
            const allWhite = grid.every(row => row.every(cell => cell === 0)); // Check if all cells are 0
            if (allWhite) {
                setTimeout(() => alert(`Congratulations! You turned all the cells white! 🎉\nYou completed the game in ${clickCount} steps.`), 100);
            }
        }

        // Initial render
        initializeGrid();
    </script>
</body>
</html>
相关推荐
Coder_Boy_21 小时前
基于SpringAI的在线考试系统-成绩管理功能实现方案
开发语言·前端·javascript·人工智能·spring boot
幻云201021 小时前
Python深度学习:从筑基与巅峰
前端·javascript·vue.js·人工智能·python
Light6021 小时前
庖丁解牛:深入JavaScript内存管理,从内存泄漏到AI赋能的性能优化
javascript·人工智能·性能优化·内存管理·垃圾回收·内存泄漏·v8引擎
_OP_CHEN21 小时前
【前端开发之HTML】(三)HTML 常见标签(下):图文、链接与实战,解锁网页交互新姿势!
前端·html·交互·前端开发·网页开发·界面美化
3345543221 小时前
vue表格遍历根据表头里的类型和每行的状态来判断
javascript·vue.js·chrome
岳哥i1 天前
vue鼠标单机复制文本
javascript
jacGJ1 天前
记录学习--文件读写
java·前端·学习
毕设源码-赖学姐1 天前
【开题答辩全过程】以 基于WEB的实验室开放式管理系统的设计与实现为例,包含答辩的问题和答案
前端
幻云20101 天前
Python深度学习:从筑基到登仙
前端·javascript·vue.js·人工智能·python
我即将远走丶或许也能高飞1 天前
vuex 和 pinia 的学习使用
开发语言·前端·javascript