扑克牌游戏-HTML5拖放API实践

2024-03-28 09:59

本文主要是介绍扑克牌游戏-HTML5拖放API实践,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

扑克牌游戏-HTML5拖放API实践

  • 实验要求
    • HTML代码
    • style.css
    • function.js

实验要求

设计一款扑克牌拖放小游戏。在网页中插入A框和B框。
要求用户拖动从A框拖动5张连续的扑克牌至B框,完成游戏。具体要求:
1.初始时,A框包含13张随机乱序后的同花色扑克牌,以背面显示。
2.用户可任意拖动其中一张扑克牌至B框,扑克牌以正面展示。
3.用户也可将扑克牌从B框拖至A框,扑克牌会自动回到初始的位置,且背面展示。
4.B框最多能够容纳5张扑克牌。在接收到5张扑克牌后,如果满足顺子要求,则提示用户游戏结束并显示用户成绩(拖动次数)。若不满足要求,用户必须先将其中不满足的牌拖回A框,游戏方可继续。

HTML代码

<!DOCTYPE html>
<html>
<head><title>扑克游戏</title><link rel="stylesheet" type="text/css" href="./css/style.css"><script src="./js/function.js"></script></head>
<p>已拖放次数: <span id="counter">0</span></p>
<body onload="imgset()"><div id="boxA" ondrop="drop2(event)" ondragover="allowDrop(event)">A框<br><img src="" id="1" draggable="true" ondragstart="drag(event)" onerror="event.target.src='./image/pk/pkb.jpg'"><img src="" id="2" draggable="true" ondragstart="drag(event)" onerror="event.target.src='./image/pk/pkb.jpg'"><img src="" id="3" draggable="true" ondragstart="drag(event)" onerror="event.target.src='./image/pk/pkb.jpg'"><img src="" id="4" draggable="true" ondragstart="drag(event)" onerror="event.target.src='./image/pk/pkb.jpg'"><img src="" id="5" draggable="true" ondragstart="drag(event)" onerror="event.target.src='./image/pk/pkb.jpg'"><img src="" id="6" draggable="true" ondragstart="drag(event)" onerror="event.target.src='./image/pk/pkb.jpg'"><img src="" id="7" draggable="true" ondragstart="drag(event)" onerror="event.target.src='./image/pk/pkb.jpg'"><img src="" id="8" draggable="true" ondragstart="drag(event)" onerror="event.target.src='./image/pk/pkb.jpg'"><img src="" id="9" draggable="true" ondragstart="drag(event)" onerror="event.target.src='./image/pk/pkb.jpg'"><img src="" id="10" draggable="true" ondragstart="drag(event)"onerror="event.target.src='./image/pk/pkb.jpg'"><img src="" id="11" draggable="true" ondragstart="drag(event)"onerror="event.target.src='./image/pk/pkb.jpg'"><img src="" id="12" draggable="true" ondragstart="drag(event)"onerror="event.target.src='./image/pk/pkb.jpg'"><img src="" id="13" draggable="true" ondragstart="drag(event)"onerror="event.target.src='./image/pk/pkb.jpg'"></div><div id="boxB" ondrop="drop(event)" ondragover="allowDrop(event)">B框<br></div></body>
</html>

style.css

div#boxA{width: 450px;height: 650px;border: solid;float: left;padding: 20px;margin: 20px 20px 20px 20px;}
div#boxB{width: 450px;height: 650px;border: solid;float: left;padding: 20px;margin: 20px 20px 20px 20px;
}img {float: left;width: 105px;height: 150px;background-image: url(../image/pk/pkb.jpg);  background-repeat: no-repeat;  background-size: cover;  display: block;}

function.js

这边的图片命名我是以a,b,c,d分为四组,然后以扑克牌面3为1,以此类推:
感觉我描述抽象的可以看图

Alt

//计数器
var counter=0;//随机数生成
function RandomNum(Min,Max){var num = Min + Math.round(Math.random() * (Max - Min)); return num;
}//判断数组是否有重复数字
function  isRepeat(arr) {var hash = {}for (var i in arr) {if (hash[arr[i]]) { return true }hash[arr[i]] = true}return false}//扑克牌生成    
var defaultImg='./image/pk/pkb.jpg';//默认牌背
var srcData=[];//储存生成后图片src路径	
function imgset() {var arr=[];  switch(RandomNum(1,4)){case 1://红桃组groupStr="a";break;case 2://方块组groupStr="b";break;case 3://黑桃组groupStr="c";break;case 4://梅花组groupStr="d";break;default:break;}for (var i=1; i <= 13; i++) { arr[i]=RandomNum(1,13);do{arr[i]=RandomNum(1,13)srcData[i]="./image/pk/"+groupStr+arr[i]+".jpg";}while(isRepeat(arr));if (isRepeat(arr)==false) {srcData[i]="./image/pk/"+groupStr+arr[i]+".jpg";  }}}//拖拽事件
function allowDrop(ev){ev.preventDefault();
}function drag(ev){ev.dataTransfer.setData("Text", ev.target.id);var imgSrc=document.getElementById(ev.target.id).src;document.getElementById(ev.target.id).src=srcData[ev.target.id];
}function drop(ev){ev.preventDefault();    var data=ev.dataTransfer.getData("Text");    var targetElement = ev.target;     // 检查目标元素的id,以确定是哪个box  if (targetElement.id == 'boxB') {  // 如果是boxB,检查子元素数量  if (targetElement.childElementCount >5) {    // 如果子元素数量大于或等于5,则不允许放置  alert("不能超过5个元素");    return;    }}  // 如果子元素数量小于5,或者目标是boxA,则允许放置  targetElement.appendChild(document.getElementById(data)); document.getElementById(data).src=srcData[data];counter++;//计数器document.getElementById("counter").innerHTML=counter;//拖放次数//src转数字并存数组let div=document.getElementById("boxB");let imgElements=div.getElementsByTagName("img");let srcValues=[];//只装入src数字for(let i=0;i<imgElements.length;i++){let imgSrc=imgElements[i].src.slice(-5);//slice取后五个字符let match=imgSrc.match(/\d+/);if(match){srcValues.push(parseInt(match[0]));}}//判断if (targetElement.id == 'boxB') {    if (targetElement.childElementCount ==6) {   //5个元素时候触发if(areNumbersConsecutive(srcValues)){alert("恭喜完成游戏,一共花费次数:"+counter);}}}  }function drop2(ev){//放回,恢复背面ev.preventDefault();    var data=ev.dataTransfer.getData("Text");    var targetElement = ev.target;targetElement.appendChild(document.getElementById(data)); document.getElementById(data).src=defaultImg;counter++;document.getElementById("counter").innerHTML=counter;
}//是否是连续
function areNumbersConsecutive(arr) {  arr.sort((a, b) => a - b); // 对数组进行排序  for (let i = 1; i < arr.length; i++) {  if (arr[i] - arr[i - 1] !== 1) { // 检查每对相邻元素的差值是否为1  return false;  }  }  return true;  
}

实现效果
效果页面
请添加图片描述

以上代码还有许多可以优化的地方,请自行对其增减优化,我就不在优化了,最后扑克图片啥的请自备哈。目前还有俩已知BUG没改,自行探索
当然不是因为懒
请添加图片描述
当然还有另外的实现方法我在这放个连接:HTML实验三: 扑克牌拖放小游戏

这篇关于扑克牌游戏-HTML5拖放API实践的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/855293

相关文章

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

tomcat多实例部署的项目实践

《tomcat多实例部署的项目实践》Tomcat多实例是指在一台设备上运行多个Tomcat服务,这些Tomcat相互独立,本文主要介绍了tomcat多实例部署的项目实践,具有一定的参考价值,感兴趣的可... 目录1.创建项目目录,测试文China编程件2js.创建实例的安装目录3.准备实例的配置文件4.编辑实例的

Python 中的异步与同步深度解析(实践记录)

《Python中的异步与同步深度解析(实践记录)》在Python编程世界里,异步和同步的概念是理解程序执行流程和性能优化的关键,这篇文章将带你深入了解它们的差异,以及阻塞和非阻塞的特性,同时通过实际... 目录python中的异步与同步:深度解析与实践异步与同步的定义异步同步阻塞与非阻塞的概念阻塞非阻塞同步

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

基于Flask框架添加多个AI模型的API并进行交互

《基于Flask框架添加多个AI模型的API并进行交互》:本文主要介绍如何基于Flask框架开发AI模型API管理系统,允许用户添加、删除不同AI模型的API密钥,感兴趣的可以了解下... 目录1. 概述2. 后端代码说明2.1 依赖库导入2.2 应用初始化2.3 API 存储字典2.4 路由函数2.5 应

Vue中组件之间传值的六种方式(完整版)

《Vue中组件之间传值的六种方式(完整版)》组件是vue.js最强大的功能之一,而组件实例的作用域是相互独立的,这就意味着不同组件之间的数据无法相互引用,针对不同的使用场景,如何选择行之有效的通信方式... 目录前言方法一、props/$emit1.父组件向子组件传值2.子组件向父组件传值(通过事件形式)方

css中的 vertical-align与line-height作用详解

《css中的vertical-align与line-height作用详解》:本文主要介绍了CSS中的`vertical-align`和`line-height`属性,包括它们的作用、适用元素、属性值、常见使用场景、常见问题及解决方案,详细内容请阅读本文,希望能对你有所帮助... 目录vertical-ali

springboot集成Deepseek4j的项目实践

《springboot集成Deepseek4j的项目实践》本文主要介绍了springboot集成Deepseek4j的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录Deepseek4j快速开始Maven 依js赖基础配置基础使用示例1. 流式返回示例2. 进阶

浅析CSS 中z - index属性的作用及在什么情况下会失效

《浅析CSS中z-index属性的作用及在什么情况下会失效》z-index属性用于控制元素的堆叠顺序,值越大,元素越显示在上层,它需要元素具有定位属性(如relative、absolute、fi... 目录1. z-index 属性的作用2. z-index 失效的情况2.1 元素没有定位属性2.2 元素处

Python实现html转png的完美方案介绍

《Python实现html转png的完美方案介绍》这篇文章主要为大家详细介绍了如何使用Python实现html转png功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 1.增强稳定性与错误处理建议使用三层异常捕获结构:try: with sync_playwright(