首页 > 其他分享 >HTML2048小游戏(最新版)

HTML2048小游戏(最新版)

时间:2024-07-17 12:57:19浏览次数:26  
标签:case boardSize ++ HTML2048 小游戏 let board tile 最新版

比上一篇文章的2048更好一点。 控制方法:WASD键(小写)或页面上四个按钮

效果图如下:                 源代码在图片后面   

源代码

 ·HTML·

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>2048 Game</title>
    <link rel="stylesheet" href="styles.css">
</head>
<body>
    <div id="game-container">
        <div id="game-board"></div>
        <div id="controls">
            <button id="up">W</button>
            <button id="left">A</button>
            <button id="down">S</button>
            <button id="right">D</button>
        </div>
    </div>
    <script src="script.js"></script>
</body>
</html>

 ·CSS·

* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    font-family: 'Arial', sans-serif;
}

body {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100vh;
    background-color: #faf8ef;
}

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

#game-board {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: repeat(4, 1fr);
    gap: 10px;
    background-color: #bbada0;
    padding: 10px;
    border-radius: 10px;
    margin-bottom: 20px;
}

.tile {
    width: 80px;
    height: 80px;
    background-color: #cdc1b4;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 24px;
    border-radius: 10px;
    transition: all 0.2s ease-in-out;
}

#controls {
    display: flex;
    gap: 10px;
}

button {
    width: 60px;
    height: 60px;
    font-size: 20px;
    border-radius: 10px;
    background-color: #8f7a66;
    color: white;
    border: none;
    cursor: pointer;
}

button:hover {
    background-color: #9f8b76;
}

  ·JavaScript·

document.addEventListener('DOMContentLoaded', () => {
    const boardSize = 4;
    let board = [];
    let score = 0;

    const gameBoard = document.getElementById('game-board');
    const buttons = {
        up: document.getElementById('up'),
        down: document.getElementById('down'),
        left: document.getElementById('left'),
        right: document.getElementById('right')
    };

    function initBoard() {
        for (let i = 0; i < boardSize * boardSize; i++) {
            const tile = document.createElement('div');
            tile.classList.add('tile');
            gameBoard.appendChild(tile);
        }
        board = Array.from(document.querySelectorAll('.tile'));
        generateTile();
        generateTile();
        updateBoard();
    }

    function generateTile() {
        let emptyTiles = board.filter(tile => !tile.textContent);
        if (emptyTiles.length > 0) {
            let randomTile = emptyTiles[Math.floor(Math.random() * emptyTiles.length)];
            randomTile.textContent = Math.random() < 0.9 ? '2' : '4';
        }
    }

    function updateBoard() {
        board.forEach(tile => {
            const value = tile.textContent;
            tile.style.backgroundColor = getTileColor(value);
        });
    }

    function getTileColor(value) {
        switch (value) {
            case '2': return '#eee4da';
            case '4': return '#ede0c8';
            case '8': return '#f2b179';
            case '16': return '#f59563';
            case '32': return '#f67c5f';
            case '64': return '#f65e3b';
            case '128': return '#edcf72';
            case '256': return '#edcc61';
            case '512': return '#edc850';
            case '1024': return '#edc53f';
            case '2048': return '#edc22e';
            default: return '#cdc1b4';
        }
    }

    function move(direction) {
        switch (direction) {
            case 'up': moveUp(); break;
            case 'down': moveDown(); break;
            case 'left': moveLeft(); break;
            case 'right': moveRight(); break;
        }
        generateTile();
        updateBoard();
    }

    function moveUp() {
        for (let i = 0; i < boardSize; i++) {
            let column = [];
            for (let j = 0; j < boardSize; j++) {
                column.push(board[i + j * boardSize].textContent);
            }
            let newColumn = slideTiles(column);
            for (let j = 0; j < boardSize; j++) {
                board[i + j * boardSize].textContent = newColumn[j];
            }
        }
    }

    function moveDown() {
        for (let i = 0; i < boardSize; i++) {
            let column = [];
            for (let j = 0; j < boardSize; j++) {
                column.push(board[i + j * boardSize].textContent);
            }
            let newColumn = slideTiles(column.reverse()).reverse();
            for (let j = 0; j < boardSize; j++) {
                board[i + j * boardSize].textContent = newColumn[j];
            }
        }
    }

    function moveLeft() {
        for (let i = 0; i < boardSize; i++) {
            let row = [];
            for (let j = 0; j < boardSize; j++) {
                row.push(board[i * boardSize + j].textContent);
            }
            let newRow = slideTiles(row);
            for (let j = 0; j < boardSize; j++) {
                board[i * boardSize + j].textContent = newRow[j];
            }
        }
    }

    function moveRight() {
        for (let i = 0; i < boardSize; i++) {
            let row = [];
            for (let j = 0; j < boardSize; j++) {
                row.push(board[i * boardSize + j].textContent);
            }
            let newRow = slideTiles(row.reverse()).reverse();
            for (let j = 0; j < boardSize; j++) {
                board[i * boardSize + j].textContent = newRow[j];
            }
        }
    }

    function slideTiles(tiles) {
        let newTiles = tiles.filter(tile => tile);
        for (let i = 0; i < newTiles.length - 1; i++) {
            if (newTiles[i] === newTiles[i + 1]) {
                newTiles[i] = (parseInt(newTiles[i]) * 2).toString();
                newTiles[i + 1] = '';
            }
        }
        newTiles = newTiles.filter(tile => tile);
        while (newTiles.length < boardSize) {
            newTiles.push('');
        }
        return newTiles;
    }

    buttons.up.addEventListener('click', () => move('up'));
    buttons.down.addEventListener('click', () => move('down'));
    buttons.left.addEventListener('click', () => move('left'));
    buttons.right.addEventListener('click', () => move('right'));

    document.addEventListener('keydown', (e) => {
        switch (e.key) {
            case 'w': move('up'); break;
            case 's': move('down'); break;
            case 'a': move('left'); break;
            case 'd': move('right'); break;
        }
    });

    initBoard();
});

标签:case,boardSize,++,HTML2048,小游戏,let,board,tile,最新版
From: https://blog.csdn.net/w11111xxxl/article/details/140485295

相关文章

  • 2024最新版Python安装详细教程!一键安装,永久使用
    打开上面的Python官网地址,如下图所示,鼠标放入网页Downloads栏目,选择里面的windows操作系统。三、进入windows对应的页面,选择python版本(1)选择python的稳定发布版本StableReleases点击进入windows操作系统对应的页面,显示python安装版本,这些python安装版本适合windows操......
  • 最新版康泰克完整版- Kontakt v7.10.5 for Win和Mac,支持m芯片和intel,有入库工具
    一。世界最受欢迎的采样器的新篇章    NativeInstrumentsKontakt是采样器领域的标准,您将获得高质量的滤波器,在这里您将找到经典的模拟电路和最现代的滤波器。每一个都可以根据您的口味进行定制,并且由于它,您可以获得前所未有的声音。这是一个解锁版本,这意味着您可以......
  • 微信小游戏 彩色试管 倒水游戏 逻辑 (二)
     最近开始研究微信小游戏,有兴趣的可以关注一下公众号,记录一些心路历程和源代码。定义一个Waterclass1.**定义接口和枚举**:  -`WaterInfo`接口定义了水的颜色、高度等信息。  -`PourAction`枚举定义了水的倒动状态,包括无动作、加水、倒水。2.**类`Wa......
  • 小游戏对接广告联盟变现的APP开发 源码搭建
    小游戏对接广告联盟变现的APP开发在源码搭建方面涉及多个步骤和考虑因素。以下是一个概述:需求分析与定位:确定游戏类型(如休闲、益智、动作等)、目标用户群体以及游戏的核心玩法1。研究市场趋势,了解类似游戏的成功因素,以及广告联盟的选择和收益模式1。游戏设计与开发:设计游戏......
  • Cocos 打包微信小游戏,关闭load插屏
    最近开始研究微信小游戏,有兴趣的可以关注一下公众号,记录一些心路历程和源代码。一共有2个load如图下这个在构建小程序项目之后我们打开 first-screen.js 找到 tick方法里的 draw注释掉运行微信小游戏就没有那个load了。在构建发布时可以选择不勾选或者更......
  • 『粽享端午』交互小程序 小游戏 案例赏析
    在这片古老而又年轻的土地上,地域的差异孕育了丰富多彩的饮食文化。粽子,作为端午节的象征,承载着南咸北甜的口味之争,自古便在人们舌尖上演绎着不同的风味传奇。然而,在快节奏的现代生活洪流中,我们渐渐失去了亲手包裹粽子的那份闲情逸致。那份包裹在绿意中的温情与乐趣,似乎已成......
  • 好玩小游戏(有bug私聊我)
    城市守卫战2.7#include<bits/stdc++.h>#include<windows.h>#include<conio.h>#include<time.h>usingnamespacestd;intt,nl,dl,Money,Moo,Dao,Yi,Shan,Qing,Hu;intBiao,Biaob,Bao=1,Baob,Baod=1,Baodb,Hub,Fengb,Sha,Jian,Shab,Jianb,Wei;......
  • 修仙小游戏4.0(更新武器,接下来要更新防具)
    话不多说,直接放代码:#include<bits/stdc++.h>#include<iostream>#include<conio.h>#include<string>#include<map>#include<cmath>#include<windows.h>#include<time.h>#include<fstream>#include<wind......
  • 撸包小游戏对接广告联盟APP系统开发源码搭建
    “撸包小游戏广告联盟APP”源码搭建涉及多个关键步骤,以下是一个简化的流程:市场调研与需求分析:对市场进行深入调研,了解目标用户群体和他们的需求。分析竞争对手的小游戏和广告策略,确定自己小游戏的特色和定位。游戏开发:根据市场调研的结果,设计并开发具有吸引力的撸包小......
  • Java面向对象小游戏--文字版格斗游戏(附带全套源代码)->基于JavaBean
    一、前言java部分的基础学习已经完结,接下来给大家分享的大多为java相关的案例分析,也会有一些小项目,这点不要太过于担心,主要还是基础部分要打牢固。java部分的难点就在面向对象这一点,学习C语言的小伙伴们应该是第一次听说方法。这点也是和C语言相差巨大的地方,不过对于学习过pyt......