bootstrap实现九宫格效果(猫捉老鼠游戏)

最近,孩子的幼儿园让家长体验“半日助教活动”,每个家长需要讲授15-20分钟的课程。作为一名程序员,实在没有能教的课程,只能做了一个小游戏,带着小朋友们熟悉数字。

效果大致是这样的。九宫格的左上角是一只小猫图片,右下角是小老鼠图片,其他7个方框都是数字。方框被点击时背景图片就会变成小猫,每次点击都相当于小猫移动了一步,直到点击老鼠,老鼠的图片被替换,相当于猫捉到老鼠了。

 废话不多说,直接上代码。

html:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <!-- 引入bootstrap -->
    <link rel="stylesheet" href="https://cdn.staticfile.org/twitter-bootstrap/3.3.7/css/bootstrap.min.css"> 
    <link rel="stylesheet" href="./css/d1g.css">
    <title>九宫格图片</title>
</head>
<body>
    <!-- 操作区 -->
    <div id="imgInfo">
		<button id="fileBtn" class="btn btn-info">当前为第1关</button>
		<br>
        <button id="updateUrl"class="btn btn-info">第2关</button>
        <button id="clearInput"class="btn btn-primary">第3关</button>
		<button id="tsBtn"class="btn btn-warning">提示</button>
		<button id="resetBtn"class="btn btn-success">重新开始</button>
        <br>
    </div>
    <!-- 九宫格图片 -->
    <div class="wrap" id="wrap">
        <div class="box" id="box1"></div>
        <div class="box" id="box2"></div>
        <div class="box" id="box3"></div>
        <div class="box" id="box4"></div>
        <div class="box" id="box5"></div>
        <div class="box" id="box6"></div>
        <div class="box" id="box7"></div>
        <div class="box" id="box8"></div>
        <div class="box" id="box9"></div>
    </div>
</body>
<!-- 引入js文件 -->
<script src="./js/d1g.js"></script>
</html>

css:

/* 按钮容器 */
#imgInfo{
    margin: 20px;
    text-align: center;
	width: 100%;
	height: 20%;
}
#fileBtn{
    margin-bottom: 3.125rem;
}

#updateBtn{
    padding-right: 3.125rem;
}

/* 九宫格  */
.wrap{
    width: 1806px;
    height: 1806px;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-content: space-between;
}
.wrap > .box{
    width: 600px;
    height: 600px;
	background-repeat: no-repeat;
	background-size: cover;
}

js:

window.onload = function(xh){
	var intNum = 1;
    // 获取视口宽度
    var screenWidth = window.innerWidth;
    // 获取视口高度
    var screenHeight = window.innerHeight;
	
	var wrap = document.querySelector('#wrap');
	
	var wrapWidth = screenHeight*0.78 + 'px'
	var btnWidth = screenWidth*0.2 + 'px'
	var btnHeight = screenHeight*0.06 + 'px'
	var fontHeight = screenHeight*0.06/2 + 'px'
	wrap.style.width =wrapWidth;
	wrap.style.height =wrapWidth;
	
	//获取元素
	var fileBtn = document.querySelector('#fileBtn')
	fileBtn.style.width = btnWidth;
	fileBtn.style.height = btnHeight;
	fileBtn.style.fontSize = fontHeight; // 将字体大小设置
    var updateBtn = document.querySelector('#updateUrl')//第2关
    var clearBtn = document.querySelector('#clearInput')//第3关
	var tsBtn = document.querySelector('#tsBtn')//提示
	var resetBtn = document.querySelector('#resetBtn')//重新开始
	/*设置按钮属性*/
	updateBtn.style.width = screenWidth*0.1 + 'px';
	updateBtn.style.height = screenHeight*0.04 + 'px';
	updateBtn.style.fontSize = screenHeight*0.04/2 + 'px';
	
	clearBtn.style.width = screenWidth*0.1 + 'px';
	clearBtn.style.height = screenHeight*0.04 + 'px';
	clearBtn.style.fontSize = screenHeight*0.04/2 + 'px';
	
	tsBtn.style.width = screenWidth*0.1 + 'px';
	tsBtn.style.height = screenHeight*0.04 + 'px';
	tsBtn.style.fontSize = screenHeight*0.04/2 + 'px';
	
	resetBtn.style.width = screenWidth*0.1 + 'px';
	resetBtn.style.height = screenHeight*0.04 + 'px';
	resetBtn.style.fontSize = screenHeight*0.04/2 + 'px';
	
	resetBtn.onclick = function(){
        window.onload(2)
    }
    var maskBox = document.querySelector("#mask")
    //监听 更新 按钮的点击
    updateBtn.onclick = function(){
        window.open('./d2g.html');
    }
    //监听 清空 按钮的点击
    clearBtn.onclick = function(){
        window.open('./d3g.html');
    }
	if(xh!=2){
		//开始配音
		var audio = new Audio('./audio/py7.MP3');
		// 播放音频
		audio.play();
	}
	//加载图片
	//获取所有格子
	var box = document.getElementsByClassName('box')
	//为每个容器设置背景图的url
	for(var i=0;i<box.length;i++){
		box[i].style.width =screenHeight*0.26 + 'px';
		box[i].style.height =screenHeight*0.26 + 'px';
		box[i].style.border = '1.5px solid white'
		var j = i+1;
		let selector = `#box${j}`;
		if(i==0){
			document.querySelector(selector).style.backgroundImage = `url('./img/xm1.png')`
		}
		if(i>0&i<8){
			document.querySelector(selector).style.backgroundImage = `url('./img/sz${j}.jpg')`
		}
		if(i==8){
			document.querySelector(selector).style.backgroundImage = `url('./img/ls1.png')`
		}
	}
	tsBtn.onclick = function(){
	    audio = new Audio('./audio/py1.MP3');
	    // 播放音频
	    audio.play();
	}
	//选中点击数字图片事件
	document.querySelectorAll('.box').forEach(function(element) {
	    element.addEventListener('click', function(event) {
	        var kjId = this.id
			const numbers = kjId.match(/\d+/g);
			for(var i=1;i<9;i++){
				if(i!=numbers){
					let selector = `#box${i}`;
					document.querySelector(selector).style.backgroundImage = `url('./img/sz${i}.jpg')`
				}
			}
			document.querySelector(`#${this.id}`).style.backgroundImage = `url('./img/xm1.png')`
			audio = new Audio('./audio/py13.MP3');
			// 播放音频
			audio.play();
			if(numbers==9){
				document.querySelector(`#${this.id}`).style.backgroundImage = `url('./img/xm2.png')`
				pauseSeconds(0.5, () => {
				  audio = new Audio('./audio/py3.MP3');
				  // 播放音频
				  audio.play();
				})
			}
	    });
	})
	function pauseSeconds(seconds, callback) {
	  setTimeout(callback, seconds * 1000);
	}
}

图片我就不上传了,读者自行放几张就OK~快去试试吧~~~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/644547.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

一张图片中有多个一样的目标物体,分别进行识别定位分割(Python实现)

需求&#xff1a; 一张图片中有多个目标物体&#xff0c;将多个目标物体进行识别分割定位 import cv2 import numpy as npdef show_photo(name,picture):cv2.imshow(name,picture)cv2.waitKey(0)cv2.destroyAllWindows()img_path r"test3.png" img cv2.imread(img…

社交媒体数据恢复:聊天宝

请注意&#xff0c;本教程仅针对聊天宝应用程序&#xff0c;而非其他聊天软件。以下是详细的步骤&#xff1a; 首先&#xff0c;请确保您已经登录了聊天宝应用程序。如果您尚未登录&#xff0c;请使用您的账号登录。 在聊天宝主界面&#xff0c;找到您希望恢复聊天记录的对话框…

LeetCode - 数组 - 四数之和

题目地址 描述 给你一个由 n 个整数组成的数组 nums &#xff0c;和一个目标值 target 。请你找出并返回满足下述全部条件且不重复的四元组 [nums[a], nums[b], nums[c], nums[d]] &#xff08;若两个四元组元素一一对应&#xff0c;则认为两个四元组重复&#xff09;&#x…

【机器学习与大模型】驱动下的应用图像识别与处理

摘要&#xff1a; 本文深入探讨了机器学习在图像识别与处理领域的应用&#xff0c;特别是在大模型的推动下所取得的巨大进展。详细阐述了图像识别与处理的基本原理、关键技术&#xff0c;以及机器学习算法和大模型如何提升其性能和准确性。通过实际案例分析了其在多个领域的广泛…

[WUSTCTF2020]level3

base64换表 但是这的表有一个引用 模拟执行 #DRKCTF{}aABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789/ flag[ord(i) for i in a] for i in range(0,10):flag[i],flag[19-i]flag[19-i],flag[i] for i in flag:print(chr(i),end)新表 TSRQPONMLKJIHGFEDCBAU…

技术速递|无障碍应用程序之旅:键盘可访问性和 .NET MAUI

作者&#xff1a;Rachel Kang 排版&#xff1a;Alan Wang 首先让我们一起来看看您的应用程序是否支持键盘访问&#xff1a; 启动您的其中一个应用。如果您的设备尚未连接物理键盘&#xff0c;请连接物理键盘。像平常一样导航您的应用程序&#xff0c;并且仅使用键盘来执行此操…

DI-engine强化学习入门(三)DI-ZOO强化学习环境搭建与示例运行——Atari

Atari是一家知名的电子游戏公司&#xff0c;成立于1972年&#xff0c;是早期电子游戏产业的先驱之一。在强化学习领域&#xff0c;提到Atari通常指的是Atari 2600游戏的一系列环境&#xff0c;这些环境是用于开发和测试强化学习算法的标准平台。 Atari 2600 强化学习环境概述 …

ABC354学习笔记

高桥有一棵植物&#xff0c;这个植物在第 0 0 0 天时高度为 0 c m 0\,\mathrm{cm} 0cm&#xff0c;此后的第 i i i 天&#xff0c;他的植物会增高 2 i c m 2^i\,\mathrm{cm} 2icm。 高桥身高为 H c m H\,\mathrm{cm} Hcm。 高桥想知道在第几天&#xff0c;他的植物的高度会…

Vue移动端登录页面

使用的是vant组件&#xff0c;引用和使用组件请去官网学习&#xff0c;链接↓vant组件官网 <div class"center"><!-- 背景图片 --><div class"background"><imgsrc"/assets/background.jpg"width"100%"heigh…

STL题单总结

下周争取全部刷掉 牛客 知乎推荐的题 收藏的文章1 收藏的文章2 收藏的文章3 洛谷题单

ICQ 将于 6 月关闭,这是一种奇怪的方式,发现它在 2024 年仍然活跃

你知道ICQ还活着吗&#xff1f;不过&#xff0c;不要太兴奋;它将永远消失。 还记得ICQ吗&#xff1f;如果你这样做了&#xff0c;你可能会记得它是AOL在1998年购买的Messenger客户端&#xff0c;就在Yahoo Instant Messager和MSN Messenger加入竞争的时候。然后Skype出现了&…

嵌入式全栈开发学习笔记---C语言笔试复习大全23

目录 联合体 联合体的定义 联合体的长度 如果来判断设备的字节序&#xff1f; 如何把大端数据转换成小端数据&#xff1f; 枚举 枚举的定义 上一篇复习了结构体&#xff0c;这一节复习联合体和枚举。 说明&#xff1a;我们学过单片机的一般都是有C语言基础的了&#xff…

【资讯】5月巴塞罗那,东胜物联边缘计算网关亮相IOTSWC AWS展台

2024年5月21-23日&#xff0c;物联网解决方案世界大会 IOT SWC 在巴塞罗那举行&#xff0c;这是数字化转型趋势和颠覆性技术的顶级盛会。 作为AWS的硬件合作伙伴&#xff0c;东胜物联网边缘计算网关DSGW-210将在AWS展台1号馆展出&#xff0c;欢迎大家前来参观。 此次东胜在AW…

【Linux】写时拷贝技术COW (copy-on-write)

文章目录 Linux写时拷贝技术(copy-on-write)进程的概念进程的定义进程和程序的区别PCB的内部构成 程序是如何被加载变成进程的&#xff1f;写时复制&#xff08;Copy-On-Write, COW&#xff09;写时复制机制的原理写时拷贝的场景 fork与COWvfork与fork Linux写时拷贝技术(copy-…

阿里云、百度云和移动云的对象存储横向性能对比

文章目录 前言一、对比测试的方法和标准A. 测试环境的设置 二、对比测试的结果A、阿里云OSS测试结果2.B. 百度云结果C. 移动云结果分析与结论 总结 前言 在企业的数字化转型进程中&#xff0c;我们观察到越来越多的公司将其IT基础设施迁移到云端。随着企业业务的持续运营&…

5.Redis之常用数据结构单线程模型

围绕每个数据结构介绍相关命令当前版本的redis支持10个数据类型 Redis 底层在实现上述数据结构的时候,会在源码层面,针对上述实现进行特定的优化,来达到 节省时间/节省空间 效果,内部的具体实现的数据结构&#xff08;编码方式&#xff09;,还会有变数redis 承诺,现在我这有个 …

pikachu靶场中的CSRF、SSRF通关

目录 1、CSRF介绍 2、CSRF&#xff08;get&#xff09; 3、CSRF&#xff08;post&#xff09; 4、CSRF Token 5、SSRF介绍 6、SSRF&#xff08;curl&#xff09; 7、SSRF&#xff08;file_get-content&#xff09; 8、CSRF与SSRF的区别 最近在学习CSRF、SSRF漏洞&#…

LeetCode HOT 100:3. 无重复字符的最长字串

1. 链接 . - 力扣&#xff08;LeetCode&#xff09; 2. 题目描述 3. 题解 方法一&#xff1a;滑动窗口 哈希表 根据题意&#xff1a; 1. 遍历所有可能的子串——利用滑动窗口表示子串&#xff1b; 2. 保证滑动窗口内不包含重复字符——需要哈希表map记录字符出现的下标。…

PostgreSQL基本使用Schema

参考文章&#xff1a;PostgreSQL基本使用&#xff08;3&#xff09;Schema_pg数据库查询schema-CSDN博客 PostgreSQL 模式&#xff08;Schema&#xff09;可以理解为是一个表的集合&#xff08;或者所属者&#xff09;。 例如&#xff1a;在 MySQL 中&#xff0c;Scheam 是库&…

etcd集群部署

1.etcd介绍 1.1 什么是etcd etcd的官方定义如下: A distributed, reliable key-value store for the most critical data of distributed systemetcd是一个Go语言编写的分布式、高可用的一致性键值存储系统,用于提供可靠的分布式键值(key value)存储、配置共享和服务发现等…