日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

原生JavaScript實(shí)現(xiàn)貪吃蛇游戲

瀏覽:26日期:2023-06-15 13:36:38

本文實(shí)例為大家分享了JavaScript實(shí)現(xiàn)貪吃蛇游戲的具體代碼,供大家參考,具體內(nèi)容如下

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='http://m.b3g6.com/bcjs/snake.js'></script></body></html>

2.JavaScript部分

var arrayBox = new Array(); // 存放單元格var arraySnake = new Array(); // 存放蛇 var food; // 食物var snakeHead; // 蛇頭var key = true; // 判斷頁(yè)面是否需要初始化var timekey; // 運(yùn)動(dòng)定時(shí)器常量function newGame() { bgInit(); arrayBoxInit(); initSnake(); randomFood();}newGame();document.onclick = function () { if (key) { gameStart(arraySnake); key = false; }}// 記錄的單元格數(shù)組初始化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'; } } }}// 隨機(jī)產(chǎn)生食物食物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(); }}// 開(kāi)始游戲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() } }}// 初始化運(yùn)動(dòng),(方向:右左上下)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);}// 鍵盤(pán)操作拐彎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);// 下拐f(shuō)unction turnDown() { if (arraySnake[arraySnake.length - 1].className.split('-')[1] == arraySnake[arraySnake.length - 2].className.split('-')[1]) { clearInterval(timekey); moveDown(); }}// 下拐f(shuō)unction turnUp() { if (arraySnake[arraySnake.length - 1].className.split('-')[1] == arraySnake[arraySnake.length - 2].className.split('-')[1]) { clearInterval(timekey); moveUp(); }}// 左拐f(shuō)unction turnLeft() { if (arraySnake[arraySnake.length - 1].className.split('-')[2] == arraySnake[arraySnake.length - 2].className.split('-')[2]) { clearInterval(timekey); moveLeft(); }}// 右拐f(shuō)unction 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); }}// 增加長(zhǎng)度在蛇尾function addSnakeLength(temp) { arraySnake.unshift(temp);}

全程獨(dú)自敲下來(lái),敲了兩個(gè)多小時(shí),基本功能都實(shí)現(xiàn)了,由于沒(méi)有參考任何東西,所以有很多很多需要優(yōu)化的地方,點(diǎn)個(gè)贊吧

更多有趣的經(jīng)典小游戲?qū)崿F(xiàn)專題,分享給大家:

C++經(jīng)典小游戲匯總

python經(jīng)典小游戲匯總

python俄羅斯方塊游戲集合

JavaScript經(jīng)典游戲 玩不停

java經(jīng)典小游戲匯總

javascript經(jīng)典小游戲匯總

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: JavaScript
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
一区视频在线| 日韩三级一区| 麻豆精品久久| 国产精品调教视频| 国产麻豆一区二区三区精品视频| 日韩有码av| 日韩精品中文字幕吗一区二区| 国产麻豆综合| 人人爽香蕉精品| 蜜臀久久久久久久| 中文字幕成人| 国产精品成人自拍| 精品国产黄a∨片高清在线| 韩国女主播一区二区三区| 麻豆精品久久| a国产在线视频| 99久久夜色精品国产亚洲1000部| 成人久久一区| 99国产精品视频免费观看一公开| 日本大胆欧美人术艺术动态| 日韩在线观看中文字幕| 国产伦精品一区二区三区千人斩 | 亚洲精品人人| 日韩一区电影| 在线综合视频| 亚洲综合国产| 亚洲精品日本| 国产精品jk白丝蜜臀av小说| 精品国产精品国产偷麻豆| 日韩欧美网址| 欧美日韩少妇| 亚洲欧洲美洲国产香蕉| 国产伦理一区| 欧美www视频在线观看| 国产专区一区| 国产劲爆久久| 日本精品不卡| 香蕉久久国产| 国产精品视频一区二区三区四蜜臂 | 中文字幕亚洲影视| 国产精品一区亚洲| 久久久久久久久久久9不雅视频| 99香蕉国产精品偷在线观看| 亚洲3区在线| 精品国产乱码久久久久久1区2匹| 精品欧美激情在线观看| 91亚洲精品在看在线观看高清| 久久免费视频66| 亚洲精品一区二区在线看| 亚洲啊v在线免费视频| 国产精品一区毛片| 国产99亚洲| 国产亚洲久久| 午夜久久久久| 麻豆精品av| 合欧美一区二区三区| 欧美精品国产| 免费美女久久99| 亚洲精品在线二区| 在线国产日韩| 国产情侣一区| 亚洲www免费| 天堂成人国产精品一区| 成人亚洲一区| 日韩中文字幕一区二区三区| 国产精品一站二站| 日韩午夜一区| 中文一区一区三区高中清不卡免费| 亚洲制服少妇| 国产videos久久| 一二三区精品| 成人va天堂| 国产亚洲久久| 国产精品普通话对白| 成人在线观看免费视频| 综合国产精品| 激情婷婷亚洲| 国产成人精品一区二区三区视频| 日本欧美韩国一区三区| 亚洲国产成人精品女人| 精品视频自拍| 午夜精品福利影院| 午夜精品亚洲| 久久久精品日韩| 精品国产网站| 国产伦精品一区二区三区千人斩| 丝袜a∨在线一区二区三区不卡| zzzwww在线看片免费| 欧美片第1页综合| 亚洲精品一级| 91国语精品自产拍| 91av亚洲| 精品久久福利| 麻豆精品国产91久久久久久| 日韩不卡一区二区三区| 国产一区导航| 久久精品观看| 中文在线а√天堂| 精品午夜av| 国产精品成人自拍| 欧美午夜三级| 婷婷综合福利| 日韩精品一级中文字幕精品视频免费观看| 激情欧美一区二区三区| 日韩国产欧美| 不卡一二三区| 91青青国产在线观看精品| 久久精品伊人| 国产精品多人| 久久久国产精品入口麻豆| 国产麻豆精品久久| 国产欧美日韩一区二区三区四区| 婷婷视频一区二区三区| 热久久免费视频| 蜜桃av一区二区在线观看| 在线国产一区二区| 亚洲黄色在线| 红桃视频欧美| 免费毛片在线不卡| 欧美手机在线| 99精品综合| 亚洲成av人片一区二区密柚| 日本一区二区高清不卡| 黑森林国产精品av| 亚洲成人不卡| 九色精品91| 久久中文字幕二区| 午夜精品婷婷| 石原莉奈在线亚洲三区| 蜜臀精品久久久久久蜜臀| 喷白浆一区二区| 亚洲精品影视| 欧美性www| 国产一区二区三区视频在线| 国产黄大片在线观看| 日韩毛片在线| 9色国产精品| 亚洲三级av| 欧美亚洲免费| 久久永久免费| 日韩欧美中文| 亚洲天堂一区二区| 国产午夜久久| 日韩av二区在线播放| 老司机精品视频网| 国产黄大片在线观看| 国产尤物精品| 蜜臀久久久99精品久久久久久| 亚洲毛片在线免费| 欧美激情91| 久久久久欧美精品| 亚洲一区欧美二区| 欧美伊人久久| 国产精品久久观看| 欧美美女一区| 日韩中文字幕无砖| 国产精品久久久久久久久久齐齐 | 亚洲五月综合| 国产劲爆久久| 日韩在线观看| 国产精品普通话对白| 91大神在线观看线路一区| 麻豆国产精品一区二区三区| 国产91精品对白在线播放| 亚洲一区av| 久久麻豆视频| 99久久精品网| 免费精品视频在线| 国产精品成人一区二区网站软件| 精品国产一区二区三区av片| 久久高清免费| 日韩激情一二三区| 青青青免费在线视频| 视频在线观看国产精品| 久久99蜜桃| 极品日韩av| 国产乱码精品一区二区三区亚洲人| 欧美成人a交片免费看| 麻豆精品网站| 国产欧美另类| 久久精品国产大片免费观看| 亚洲91在线| 亚洲不卡系列| 日韩av一区二区在线影视| 岛国av在线网站| 日韩综合一区二区| 久久亚洲精品中文字幕蜜潮电影| 7777精品| 日韩精品影视| 欧美一区二区三区久久精品| 99久精品视频在线观看视频| 国产日韩一区二区三区在线| 国产综合色产| 欧美精品91| 免费人成精品欧美精品 | 亚洲中午字幕| 国产一区二区三区四区五区传媒| 蜜臀久久久99精品久久久久久| 国产精品久久久久久久免费观看| 免费在线观看精品|