用JavaScript做一个拼图游戏

2023-10-29 12:40
文章标签 java script 拼图游戏

本文主要是介绍用JavaScript做一个拼图游戏,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

喜欢的可以复制下面完整代码查看效果在自己本地查看效果
实现难度:不算大,毕竟是小游戏
开发工具:html,css,js,jquery

版本更新

新增严谨模式判定(2023.06.04)

  1. 非严谨判定:数字按顺序排即可例:1,2,3,【空卡槽】,4,5,6,7,8
  2. 严谨判定:数字按顺序排,且空卡槽必须在最后一个卡位才算通关例:1,2,3,4,5,6,7,8,【空卡槽】

效果截图

在这里插入图片描述

完整代码

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.4/jquery.min.js"></script><linkrel="stylesheet"href="https://cdnjs.cloudflare.com/ajax/libs/animate.css/4.1.1/animate.min.css"/><style>html,body{width: 100%;height: 100%;padding: 0;margin: 0;/* background-color: #000; */color: #424242;}body{padding: 20px;box-sizing: border-box;}*{}.main-outer{}.main{width: max-content;border: 8px solid #feffa3;box-shadow: 0 0 20px 0 #666;}.row{display: flex;}/* 卡位 */.col{width: 60px;height: 60px;line-height: 50px;border-radius: 2px;font-size: 20px;font-weight: 700;text-align: center;position: relative;border: 1px solid;}/* 卡位上的拼图 */.box{height: 100%;transition: .2s;cursor: pointer;}.col.red{color: #f34949;border-color: #f34949;}.col.red:hover .box{color: #fff;background: #f34949;}.col.blue{color: #6aabff;border-color: #6aabff;}.col.blue:hover .box{color: #fff;background: #6aabff;}.top-control{/* max-width: 400px; */font-size: 14px;font-weight: 700;padding-bottom: 30px;}.label{display: inline-block;width: 70px;text-align: right;}.status.active{color: #2f93f6;}.top-control>div{height: 50px;display: flex;align-items: center;}.top-control input{border: 1px solid #c7ecff;border-radius: 6px;padding: 2px 6px;height: 26px;outline: none;}.top-control input:focus,.top-control input:hover{border-color: #2ab7ff;}.button{margin-left: 10px;padding: 4px 12px;border: 1px solid #ccc;font-weight: 600;transition: .1s;display: inline-block;cursor: pointer;}.button:hover{color: #fff;background-color: #6aabff;border-color: transparent;}/* 提示 */.tip{color: #ccc;font-size: 12px;}/* 小标签 */.tag{border: 1px solid;padding: 2px 4px;font-size: 12px;box-shadow: 0 0 4px 0;}.top-control div .tip{margin-left: 4px;}.status-text.active{color: #fe8f8f;}.enter-text{color: #73aee1;}.enter-text.active{color: #fe8f8f;}</style>
</head>
<body><!-- 控制器 --><div class="top-control"><div><span class="label">行:</span><input class="row-input" value="3" type="number" min="3"><span class="tip row-val-tip"></span></div><div><span class="label">列:</span><input class="col-input" value="3" type="number" min="3"><span class="tip col-val-tip"></span></div><div class="status"><span class="label">状态:</span><span class="status-text tag"></span><span class="chang-button button">重置</span></div><div class="enter"><span class="label">模式判定:</span><span class="enter-text tag"></span><span class="enter-type-button button">切换并重置</span></div><span class="tip">非严谨判定:数字按顺序排即可<br/>(比如1,2,3,【空卡槽】,4,5,6,7,8)<br/>严谨判定:数字按顺序排,且空卡槽必须在最后一个卡位才算通关<br/>(比如1,2,3,4,5,6,7,8,【空卡槽】)</span></div><!-- 容器 --><div class="main-outer"><div class="main"></div></div>
</body>
<script>let maxVal = 20//最大输入限制let minVal = 3//最小输入限制$('.row-val-tip').html(`最小${minVal}行,最大${maxVal}`)$('.col-val-tip').html(`最小${minVal}列,最大${maxVal}`)let rowSize = 0 //行let colSize = 0 //列let counts = []// 生成卡位数字列表let messycounts = []// 使用的卡位列表let enterType = false//是否开启严谨判定run()$('.chang-button').click(function(){$('.main').html('')run()})// 切换判定依据$('.enter-text').html(enterType?'严格':'非严格')enterType ?$('.enter-text').addClass('active') :$('.enter-text').removeClass('active');$('.enter-type-button').click(function(){enterType = !enterType$('.enter-text').html(enterType?'严格':'非严格')enterType ?$('.enter-text').addClass('active') :$('.enter-text').removeClass('active');$('.chang-button').click()})function run(){rowSize = Number($('.row-input').val())colSize = Number($('.col-input').val())rowSize = rowSize>minVal?rowSize:minValcolSize = colSize>minVal?colSize:minValrowSize = rowSize<maxVal?rowSize:maxValcolSize = colSize<maxVal?colSize:maxValcounts = Array(rowSize*colSize-1).fill(null).map((e, index)=>index+1)messycounts = [...counts]// 打乱卡位顺序messycounts.sort(()=>Math.random()-.5)Array(rowSize).fill(null).map((item, index)=>{const row = $('<div class="row"></div>')Array(colSize).fill(null).map((im, ix)=>{// ${index*colSize+ix+1} 序号const num = messycounts.shift()const box = $(`<div class="box" num="${num}">${num}</div>`)const col = $(`<div class="col blue" row="${index}" col="${ix}"></div>`)if(num){box.appendTo(col)}else{col.attr('isnull', '1')}col.appendTo(row)})row.appendTo($('.main'))})$('.status-text').html('未通过').removeClass('active')}// 拼图移动事件$(document).on('click', '.box', function(){const start = $(this).parent('.col')//当前点击卡位const startRow = Number(start.attr('row'))const startCol = Number(start.attr('col'))const target = $(`[isnull="1"]`)//目标卡位const targetRow = Number(target.attr('row'))const targetCol = Number(target.attr('col'))let flag = false// 同行if(startRow==targetRow){// 目标卡位上移1或下移1可以和当前点击卡位重合if((targetCol+1==startCol) || (targetCol-1==startCol)){flag = true}}// 同列if(startCol==targetCol){// 目标卡位左移1或右移1可以和当前点击卡位重合if((targetRow+1==startRow) || (targetRow-1==startRow)){flag = true}}if(flag){target.attr('isnull', '0')//目标卡位取消空标记start.attr('isnull', '1')//当前卡位添加空标记$(this).appendTo(target)//当前卡位的数据转移到目标卡位const nums = []$('.col .box').each((index, item)=>{nums.push($(item).attr('num'))})// 开启严谨判定后,空卡槽必须在最后一个格子if(enterType){$(`[isnull="1"]`).attr('row')==(rowSize-1) &&$(`[isnull="1"]`).attr('col')==(colSize-1) &&counts.join(',') == nums.join(',')&&$('.status-text').html('通过').addClass('active');}else{counts.join(',') == nums.join(',') &&$('.status-text').html('通过').addClass('active');}}})
</script>
</html>

这篇关于用JavaScript做一个拼图游戏的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java NoClassDefFoundError运行时错误分析解决

《JavaNoClassDefFoundError运行时错误分析解决》在Java开发中,NoClassDefFoundError是一种常见的运行时错误,它通常表明Java虚拟机在尝试加载一个类时未能... 目录前言一、问题分析二、报错原因三、解决思路检查类路径配置检查依赖库检查类文件调试类加载器问题四、常见

Java注解之超越Javadoc的元数据利器详解

《Java注解之超越Javadoc的元数据利器详解》本文将深入探讨Java注解的定义、类型、内置注解、自定义注解、保留策略、实际应用场景及最佳实践,无论是初学者还是资深开发者,都能通过本文了解如何利用... 目录什么是注解?注解的类型内置注编程解自定义注解注解的保留策略实际用例最佳实践总结在 Java 编程

Java 实用工具类Spring 的 AnnotationUtils详解

《Java实用工具类Spring的AnnotationUtils详解》Spring框架提供了一个强大的注解工具类org.springframework.core.annotation.Annot... 目录前言一、AnnotationUtils 的常用方法二、常见应用场景三、与 JDK 原生注解 API 的

Java controller接口出入参时间序列化转换操作方法(两种)

《Javacontroller接口出入参时间序列化转换操作方法(两种)》:本文主要介绍Javacontroller接口出入参时间序列化转换操作方法,本文给大家列举两种简单方法,感兴趣的朋友一起看... 目录方式一、使用注解方式二、统一配置场景:在controller编写的接口,在前后端交互过程中一般都会涉及

Java中的StringBuilder之如何高效构建字符串

《Java中的StringBuilder之如何高效构建字符串》本文将深入浅出地介绍StringBuilder的使用方法、性能优势以及相关字符串处理技术,结合代码示例帮助读者更好地理解和应用,希望对大家... 目录关键点什么是 StringBuilder?为什么需要 StringBuilder?如何使用 St

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

Java并发编程之如何优雅关闭钩子Shutdown Hook

《Java并发编程之如何优雅关闭钩子ShutdownHook》这篇文章主要为大家详细介绍了Java如何实现优雅关闭钩子ShutdownHook,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 目录关闭钩子简介关闭钩子应用场景数据库连接实战演示使用关闭钩子的注意事项开源框架中的关闭钩子机制1.

Maven中引入 springboot 相关依赖的方式(最新推荐)

《Maven中引入springboot相关依赖的方式(最新推荐)》:本文主要介绍Maven中引入springboot相关依赖的方式(最新推荐),本文给大家介绍的非常详细,对大家的学习或工作具有... 目录Maven中引入 springboot 相关依赖的方式1. 不使用版本管理(不推荐)2、使用版本管理(推

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B