一个十字翻转小游戏

有没有万能公式,我现在只会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>
相关推荐
火星思想几秒前
Webpack热更新后模块生效的完整过程
前端·webpack·架构
月亮慢慢圆2 分钟前
监视器
前端
sevenliao3 分钟前
js 继承方式有哪几种
javascript
10年前端老司机4 分钟前
微信小程序自定义组件
前端·javascript·微信小程序
cauyyl6 分钟前
react nativeWebView跨页面通信
javascript·react native·react.js
APItesterCris6 分钟前
跨平台数据采集方案:淘宝 API 对接 React Native 实现移动端实时监控
javascript·react native·react.js
brzhang10 分钟前
实时通信的那些事儿:短轮询、长轮询、SSE 和 WebSocket 到底怎么选?
前端·后端·架构
玄魂15 分钟前
开源之夏2025-VisActor 社区题目及参赛者选/培介绍
前端·开源·资讯
浪裡遊15 分钟前
TypeScript中的函数类型定义与类型约束
javascript·ubuntu·typescript
camellia16 分钟前
SpringBoot(二十四)SpringBoot集成redis哨兵集群
java·前端·后端