原生JavaScript实现贪吃蛇游戏
更新时间:2020年11月4日 11:33 点击:1940
本文实例为大家分享了JavaScript实现贪吃蛇游戏的具体代码,供大家参考,具体内容如下
1.HTML部分,东西很少
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>贪吃蛇</title> <style> *{ margin: 0px; padding: 0px; } td{ border-radius: 30%; } </style> </head> <body> <script type="text/javascript" src="./snake.js"></script> </body> </html>
2.JavaScript部分
var arrayBox = new Array(); // 存放单元格 var arraySnake = new Array(); // 存放蛇 var food; // 食物 var snakeHead; // 蛇头 var key = true; // 判断页面是否需要初始化 var timekey; // 运动定时器常量 function newGame() { bgInit(); arrayBoxInit(); initSnake(); randomFood(); } newGame(); document.onclick = function () { if (key) { gameStart(arraySnake); key = false; } } // 记录的单元格数组初始化 function arrayBoxInit() { for (var y = 0; y < 20; y++) { arrayBox[y] = new Array(); for (var x = 0; x < 20; x++) { arrayBox[y][x] = 0; } } } // 背景初始化 function bgInit() { var table = document.createElement("table"); table.style = "border-spacing:0px; border:1px solid #3c3c3c;margin:10% auto"; for (var y = 0; y < 20; y++) { var tr = document.createElement("tr"); for (var x = 0; x < 20; x++) { var td = "<td class='box-" + y + "-" + x + "' style='width: 20px; height: 20px;'></td>"; tr.innerHTML += td; } table.appendChild(tr); } document.body.insertBefore(table, document.getElementsByTagName("script")[0]); } // 初始化蛇 function initSnake() { var x = Math.floor(Math.random() * 20); var y = Math.floor(Math.random() * 20); var initA = document.getElementsByClassName("box-" + y + "-" + x)[0]; snakeHead = initA; //蛇头 var b = initBFn(x, y); var initB = document.getElementsByClassName(b)[0]; arraySnake.push(initB); arraySnake.push(initA); initA.style.backgroundColor = "#9c9c9c"; initB.style.backgroundColor = "#9c9c9c"; arrayBox[y][x] = 1; arrayBox[b.split("-")[1]][b.split("-")[2]] = 1; } // 初始化蛇身 function initBFn(x, y) { if (x != 19 && x != 0) { if (y != 19 && y != 0) { if (Math.random() > 0.5) { if (Math.random() > 0.5) { return "box-" + y + "-" + (x + 1); } else { return "box-" + y + "-" + (x - 1); } } else { if (Math.random() > 0.5) { return "box-" + (y + 1) + "-" + x; } else { return "box-" + (y - 1) + "-" + x; } } } else if (y == 0) { if (Math.random() > 0.5) { return "box-0-" + (x + 1); } else { return "box-0-" + (x - 1); } } else if (y == 19) { if (Math.random() > 0.5) { return "box-19-" + (x + 1); } else { return "box-19-" + (x - 1); } } } else if (x == 0) { if (y != 19 && y != 0) { if (Math.random() > 0.5) { return "box-" + (y + 1) + "-0"; } else { return "box-" + (y - 1) + "-0"; } } else if (y == 0) { if (Math.random() > 0.5) { return "box-1-0"; } else { return "box-0-1"; } } else if (y == 19) { if (Math.random() > 0.5) { return "box-18-0"; } else { return "box-19-1"; } } } else if (x == 19) { if (y != 19 && y != 0) { if (Math.random() > 0.5) { return "box-" + (y + 1) + "-19"; } else { return "box-" + (y - 1) + "-19"; } } else if (y == 0) { if (Math.random() > 0.5) { return "box-1-19"; } else { return "box-0-18"; } } else if (y == 19) { if (Math.random() > 0.5) { return "box-18-19"; } else { return "box-19-18"; } } } } // 随机产生食物食物 function randomFood() { var x = Math.floor(Math.random() * 20); var y = Math.floor(Math.random() * 20); if (!arrayBox[y][x]) { document.getElementsByClassName("box-" + y + "-" + x)[0].style = "background-color:#9c9c9c;border-radius:50%"; arrayBox[y][x] = 1; food = document.getElementsByClassName("box-" + y + "-" + x)[0]; } else { addSnakeLength(); } } // 开始游戏 function gameStart(arraySnake) { var Ax = arraySnake[1].className.split("-")[2]; var Ay = arraySnake[1].className.split("-")[1]; var Bx = arraySnake[0].className.split("-")[2]; var By = arraySnake[0].className.split("-")[1]; if (Ay == By) { if (Ax > Bx) { moveRight(); } else { moveLeft() } } else { if (Ay > By) { moveDown() } else { moveUp() } } } // 初始化运动,(方向:右左上下) function moveRight() { timekey = setInterval(function () { var nextBox = document.getElementsByClassName("box-" + arraySnake[arraySnake.length - 1].className.split("-")[1] + "-" + (parseInt(arraySnake[arraySnake.length - 1].className.split("-")[2]) + 1))[0]; if (nextBox) { arrayBox[arraySnake[arraySnake.length - 1].className.split("-")[1]][(parseInt(arraySnake[arraySnake.length - 1].className.split("-")[2]) + 1)] = 1; nextBox.style.backgroundColor = "#9c9c9c"; arraySnake.push(nextBox); arrayBox[arraySnake[0].className.split("-")[1]][arraySnake[0].className.split("-")[2]] = 0; arraySnake[0].style.backgroundColor = "#fff"; arraySnake.shift(); eatFood(); } }, 200); } function moveLeft() { timekey = setInterval(function () { var nextBox = document.getElementsByClassName("box-" + arraySnake[arraySnake.length - 1].className.split("-")[1] + "-" + (parseInt(arraySnake[arraySnake.length - 1].className.split("-")[2]) - 1))[0]; if (nextBox) { arrayBox[arraySnake[arraySnake.length - 1].className.split("-")[1]][(parseInt(arraySnake[arraySnake.length - 1].className.split("-")[2]) - 1)] = 1; nextBox.style.backgroundColor = "#9c9c9c"; arraySnake.push(nextBox); arrayBox[arraySnake[0].className.split("-")[1]][arraySnake[0].className.split("-")[2]] = 0; arraySnake[0].style.backgroundColor = "#fff"; arraySnake.shift(); eatFood(); } }, 200); } function moveUp() { timekey = setInterval(function () { var nextBox = document.getElementsByClassName("box-" + (parseInt(arraySnake[arraySnake.length - 1].className.split("-")[1]) - 1) + "-" + arraySnake[arraySnake.length - 1].className.split("-")[2])[0]; if (nextBox) { arrayBox[(parseInt(arraySnake[arraySnake.length - 1].className.split("-")[1]) - 1)][arraySnake[arraySnake.length - 1].className.split("-")[2]] = 1; nextBox.style.backgroundColor = "#9c9c9c"; arraySnake.push(nextBox); arrayBox[arraySnake[0].className.split("-")[1]][arraySnake[0].className.split("-")[2]] = 0; arraySnake[0].style.backgroundColor = "#fff"; arraySnake.shift(); eatFood(); } }, 200); } function moveDown() { timekey = setInterval(function () { var nextBox = document.getElementsByClassName("box-" + (parseInt(arraySnake[arraySnake.length - 1].className.split("-")[1]) + 1) + "-" + arraySnake[arraySnake.length - 1].className.split("-")[2])[0]; if (nextBox) { arrayBox[(parseInt(arraySnake[arraySnake.length - 1].className.split("-")[1]) + 1)][arraySnake[arraySnake.length - 1].className.split("-")[2]] = 1; nextBox.style.backgroundColor = "#9c9c9c"; arraySnake.push(nextBox); arrayBox[arraySnake[0].className.split("-")[1]][arraySnake[0].className.split("-")[2]] = 0; arraySnake[0].style.backgroundColor = "#fff"; arraySnake.shift(); eatFood(); } }, 200); } // 键盘操作拐弯 document.addEventListener("keydown", function (e) { if (e.code == "ArrowDown") { turnDown(); } else if (e.code == "ArrowUp") { turnUp(); } else if (e.code == "ArrowLeft") { turnLeft(); } else if (e.code == "ArrowRight") { turnRight(); } }, false); // 下拐 function turnDown() { if (arraySnake[arraySnake.length - 1].className.split("-")[1] == arraySnake[arraySnake.length - 2].className.split("-")[1]) { clearInterval(timekey); moveDown(); } } // 下拐 function turnUp() { if (arraySnake[arraySnake.length - 1].className.split("-")[1] == arraySnake[arraySnake.length - 2].className.split("-")[1]) { clearInterval(timekey); moveUp(); } } // 左拐 function turnLeft() { if (arraySnake[arraySnake.length - 1].className.split("-")[2] == arraySnake[arraySnake.length - 2].className.split("-")[2]) { clearInterval(timekey); moveLeft(); } } // 右拐 function turnRight() { if (arraySnake[arraySnake.length - 1].className.split("-")[2] == arraySnake[arraySnake.length - 2].className.split("-")[2]) { clearInterval(timekey); moveRight(); } } // 蛇吃食物 function eatFood() { var temp = food; if (arrayBox[food.className.split("-")[1]][food.className.split("-")[2]] == 0) { randomFood(); addSnakeLength(temp); } } // 增加长度在蛇尾 function addSnakeLength(temp) { arraySnake.unshift(temp); }
全程独自敲下来,敲了两个多小时,基本功能都实现了,由于没有参考任何东西,所以有很多很多需要优化的地方,点个赞吧
更多有趣的经典小游戏实现专题,分享给大家:
C++经典小游戏汇总
python经典小游戏汇总
python俄罗斯方块游戏集合
JavaScript经典游戏 玩不停
java经典小游戏汇总
javascript经典小游戏汇总
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持猪先飞。
相关文章
- 本篇文章主要分享了通过window.navigator来判断浏览器及其版本信息的实例代码。具有一定的参考价值,下面跟着小编一起来看下吧...2017-01-23
- 这篇文章主要介绍了js如何实现浏览器打印功能,文中示例代码非常详细,帮助大家更好的理解和学习,感兴趣的朋友可以了解下...2020-07-15
- 下面小编就为大家带来一篇利用JS实现点击按钮后图片自动切换的简单方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧...2016-10-25
- 作为前端,一直以来都知道HTTP劫持与XSS跨站脚本、CSRF跨站请求伪造。防御这些劫持最好的方法是从后端入手,前端能做的太少。而且由于源码的暴露,攻击者很容易绕过防御手段。但这不代表我们去了解这块的相关知识是没意义的,本文的许多方法,用在其他方面也是大有作用。...2021-05-24
- 那么今天我就用JavaScript代码来实现这个效果吧,那么首先介绍一下整个的思路,首先我们先将确定输入密码的位数,我的需求是5位,那么就用一个div标签包住5个input标签...2016-01-02
- 这篇文章主要为大家详细介绍了js+css实现回到顶部按钮back to top回到顶部按钮,感兴趣的小伙伴们可以参考一下...2016-03-03
- 这篇文章主要为大家详细介绍了js实现上传图片及时预览的相关资料,具有一定的参考价值,感兴趣的朋友可以参考一下...2016-05-09
- 这篇文章主要给大家介绍了一个关于JS正则匹配的踩坑记录,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-04-13
- 这篇文章主要介绍了如何使用JavaScript实现“无缝滚动 自动播放”轮播图效果,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2020-08-20
- 这篇文章主要给大家介绍了关于Nest.js参数校验和自定义返回数据格式的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-03-28
- 这篇文章主要介绍了node.js如何操作MySQL数据库,帮助大家更好的进行web开发,感兴趣的朋友可以了解下...2020-10-29
- 有时候我们需要屏蔽客户端的F12,以防菜鸟也可以随意修改我们的代码,也处于源码的保护等操作,这里就为大家分享一下常见的代码...2020-10-03
- 这篇文章主要介绍了基于JavaScript实现文字超出部分隐藏 的相关资料,需要的朋友可以参考下...2016-03-01
- 这篇文章主要介绍了js组件SlotMachine实现图片切换效果制作抽奖系统的相关资料,需要的朋友可以参考下...2016-04-19
- 这篇文章主要为大家详细介绍了js实现列表按字母排序,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2020-08-11
- 本文给大家介绍的是nodejs实现使用阿里大鱼短信API发送消息的方法和代码,有需要的小伙伴可以参考下。...2016-01-20
- 这篇文章主要介绍了js实现文本框输入文字个数限制代码,文本框输入的文字个数并不是无限制的,一般都会限定一个输入最高上限,如何限制,请看本文...2015-12-27
- 这篇文章主要介绍了js实现调用网络摄像头及常见错误处理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-03-07
- 这篇文章主要介绍了JS创建Tag标签的方法,结合具体实例形式分析了javascript动态操作页面HTML元素实现tag标签功能的步骤与相关操作技巧,需要的朋友可以参考下...2017-06-15
- 这篇文章主要为大家详细介绍了JS实现随机生成验证码,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-09-06