首页 前端知识 JavaScript之jQuery番外篇【打地鼠游戏的制作讲解】

JavaScript之jQuery番外篇【打地鼠游戏的制作讲解】

2024-04-07 08:04:49 前端知识 前端哥 452 849 我要收藏

(3) **双游戏模式。**增加了困难模式,设置了误伤扣分效果,提高了游戏的趣味性。

在阅读本文并开始跟着做之前,我认为你需要有

jQuery的基础知识setInterval()与setTimeout()函数与setTimeout()函数")的相关知识,值得一提的是,这些知识都可以从本人的原创博客中获取,大家如果没有掌握的可以先去掌握一些预备知识,有助于阅读本文!(注意,完整的源码和素材都在评论区置顶,大家在评论区自取即可)


I. 打地鼠游戏介绍


首先,我们看一段游戏的文字说明:

打地鼠游戏:

游戏分为两个模式:简单和困难模式,玩家可自行选择游戏的模式,其中:

(1) 简单模式:玩家会遇到从洞中随机钻出的地鼠,成功击打地鼠获得100得分。

(2) 困难模式:洞中偶尔会出现顽皮的孩童,如果误击儿童,扣除100得分,其他规则同上。

游戏支持弹窗展示本轮得分,同时具有保存历史最高战绩的功能

然后我们点这里可以在线试玩一下(请用电脑端,手机端未开发)【点我试玩】

接下来是两种模式的GIF图

1️⃣ 简单模式:


2️⃣ 困难模式:


II. 实现思路与难点讲解


📖 素材制作

首先,尽管素材我会提供给大家,但是由于大家也可以自己再去制作更精致的素材,所以还是要注意以下几个细节:

1️⃣ 素材的名称

修改素材之后,尽量按原素材的名称命名,如果一定要修改命名请同时也在源码中相应位置修改对应的名称

2️⃣ 素材的大小

由于布局的时候,素材的尺寸已经固定:洞、老鼠和小孩儿都是240px × 240px,因此大家注意换素材时,尺寸尽量按照该尺寸,如一定要修改,则在源码中一并修改布局代码

注意,完整的源码和素材都在评论区置顶,大家在评论区自取即可。


📖 总体思路

总体思路是这样的:

1️⃣ 首先,布局上,由于我们制作的重点不在动画,因此可以用几张不同的图片代替有地鼠、有孩子和空洞三种情况,通过图片的切换实现,因此布局时,可以用div嵌套img,img默认设置为空洞。(一些其他布局细节我放在下面说)

2️⃣ 其次,我们先实现简单模式:即只普通的地鼠出没,那么又有几个步骤:实现地鼠随机出没、消失;实现地鼠击打和得分;计时,例如60s;计分,统计最高分

3️⃣ 最后,我们添加困难模式,此时并不复杂,只需要素材中添加小孩出没的素材图,之后生成地鼠和小孩用随机函数随机一下,并把点击小孩设置为扣分即可。

于是,下面的部分按照这几个点逐一克服!


📖 布局注意事项

首先,强调一下布局注意事项

所有的id和class起名要规范,另外在坑洞部分同时注意每一个坑都要按照不同的class,这样我们才能用js监听和控制不同的坑的事件,因此布局代码部分是这样的:


📖 地鼠随机出没与计时实现原理

地鼠随机出没,我们可以封装一个简单的随机函数,由于我们有9个坑,于是随机数卡在1-9:

function getRandomValue() {

var random_value = Math.floor(Math.random() * 9) + 1

return random_value

}

其中用到了Math.floor()函数和Math.random()函数,后面乘上n,代表[0 - n-1]的范围,由于我们需要1-9,因此是乘9再加1。


接下来是计时的原理,我们分为两个函数实现:setInterval()和setTimeout():

1️⃣ 首先,我们需要每隔一段时间,出现一只地鼠,于是setInterval()函数就是我们需要的,因为该函数可以实现每隔一段时间自动调用函数内设置的回调函数,于是我们可以这样写:

timer = setInterval(function () {

var random_value = getRandomValue()

var $dig = $(‘.dig’ + random_value)

var $img = $dig.children(“img”)

$img.attr(“src”, “…/src/img/地鼠.png”);

},1000}

上面的设置里,我们设置了每隔1000ms(1s),就产生一只老鼠


2️⃣ 其次,我们需要让老鼠停留一会儿,这是自然的,否则怎么打地鼠,于是我们需要setTimeOut()函数:

setTimeout(function () {

$img.attr(“src”, “…/src/img/坑.png”);

}, 800)

上面的代码实现了每只老鼠停留800ms(0.8s)后消失替换成坑洞的图片。

然后我要强调一下:我们设置给setTimeout()函数的时间一定要小于等于setInterval()函数的时间,因为如果大于,那么可能出现某个坑的老鼠还没消失的同时生成一个新老鼠的bug!!!


3️⃣ 最后是实现整体的计时,这个仍然是setInterval(),我们在函数体内声明一个计时变量取值60,之后在setInterval()中每次减去1即可,当数值为0时,解除计时器

var count = 60

var timer = null

timer = setInterval(function () {

count–;

if (count < 0) {

clearInterval(timer);

}


📖 计分实现原理

计分这部分其实不难实现,我们用一个循环,把每个img元素设置点击事件监听即可,但要注意判读img元素的src属性是"坑洞"、“地鼠” 还是 “小孩儿”,因为涉及到不同的分数机制:

for (let i = 1; i <= 9; i++) {

$(“.dig” + i).children(“img”).bind(“click”, function () {

if ($(“.dig” + i).children(“img”).attr(“src”) == “…/src/img/地鼠.png”) {

$(“.dig” + i).children(“img”).attr(“src”, “…/src/img/坑.png”);

current_score += 100;

$score.html(“当前得分:” + current_score)

}

else if ($(“.dig” + i).children(“img”).attr(“src”) == “…/src/img/小孩子.png”) {

$(“.dig” + i).children(“img”).attr(“src”, “…/src/img/坑.png”);

current_score -= 100;

$score.html(“当前得分:” + current_score)

}

})

}

最高得分更不是问题了,我们设置一个全局变量,每一次在setInterval()的60s结束之后,把当前的分数与历史最高分数比较,并把较大的值赋值给历史最高分数即可:

var current_score = 0

var highest_score = 0

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
img

最后

前端CSS面试题文档,JavaScript面试题文档,Vue面试题文档,大厂面试题文档

CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!**

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
[外链图片转存中…(img-UuC33MZ0-1711912345811)]

最后

前端CSS面试题文档,JavaScript面试题文档,Vue面试题文档,大厂面试题文档

CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

[外链图片转存中…(img-nj4yHJuy-1711912345812)]

[外链图片转存中…(img-q3AJugXS-1711912345812)]

转载请注明出处或者链接地址:https://www.qianduange.cn//article/4556.html
评论
发布的文章

XML与JSON的使用

2024-08-23 21:08:27

npm i 常见问题

2024-08-23 20:08:23

大家推荐的文章
会员中心 联系我 留言建议 回顶部
复制成功!