国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

原生javascript制作貪吃蛇小游戲的方法分析

瀏覽:73日期:2023-11-09 16:13:08

本文實例講述了原生javascript制作貪吃蛇小游戲的方法。分享給大家供大家參考,具體如下:

<!--1、 創建場景 --><!-- 2、定義初始數據 以及隨機食物 --><!-- 3、控制貪吃蛇方向 --><!-- 4、判斷位置以及和隨機食物的位置 增加貪吃蛇長度 -->

HTML部分

<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <title></title> <style> html,body{ width: 100%; height: 100%; overflow: hidden; } * { margin: 0; padding: 0; } li{ width: 20px; height: 20px; border-radius: 50%; background: chocolate; position: absolute; left: 240px; top: 60px; z-index: 1; list-style: none; } #box{ position: absolute; left:240px; top: 50px; width:800px; height:600px; } </style></head><body> <span> 游戲玩法:上下左右控制小蛇的方向。 撞到邊緣游戲結束。 長按方向鍵即可加速。 </span> <ul id='box'> <li></li> <li></li> <li></li> </ul></body>

js開始

function $(id){ return document.getElementById(id); } window.onload = function () { // 創建背景 js_background(); // 隨機食物 js_food(); // 創建貪吃蛇 create_snake(); document.onkeydown = function(event){ let evt = event || window.event; switch (evt.keyCode) {case 37:direction='left';break;case 38:direction='up';break;case 39:direction='right';break;case 40:direction='down';break;default:;// console.log(evt.keyCode); } start_snake() } }

//貪吃蛇方向// 創建背景

// 貪吃蛇方向// 創建背景 var direction = 'right'; // 創建背景 function js_background(){ let bg = document.createElement('div'); bg.id = 'js_bg'; bg.style.cssText = 'position:relative;margin :50px auto; background:skyblue; width:800px; height:600px;'; document.body.appendChild(bg); }

//隨機食物

var food_left = 0; var food_top = 0; function js_food(){ food_left = parseInt(Math.random()*800/20)*20; food_top = parseInt(Math.random()*600/20)*20; let foodDiv = document.createElement('div'); foodDiv.style.cssText = 'position:absolute;width:20px; height: 20px; border-radius:50%; background:yellow;'; foodDiv.style.left = food_left+'px'; foodDiv.style.top = food_top+'px'; foodDiv.id = 'foodDiv'; $('js_bg').appendChild(foodDiv); }

//創建貪吃蛇

function create_snake(){ let lis = document.getElementsByTagName('li'); lis[0].style.backgroundColor = 'black'; lis[0].style.zIndex = 1; for(let i = 0; i < lis.length; i++){ lis[i].style.left = 280-(i*20)+'px'; lis[i].style.top = 60+'px'; } }

//定時器

// 定時器 let timre = setInterval(start_snake,200); let lis = document.getElementsByTagName('li'); function start_snake(){ let left=parseFloat(lis[0].style.left); let top= parseFloat(lis[0].style.top); // console.log(top) switch (direction) { case 'left':left = (left-20);break; case 'up':top = (top-20);break; case 'right':left = (left+20);break; case 'down':top = (top+20);break; default:; } if(left<0 || left>800-20 || top<0 || top>600-20){window.clearInterval(timre);alert('親,您Game Over');return; } // for(let i = 1; i <= lis.length-1; i++){ // lis[i].style.left = lis[i-1].style.left; // lis[i].style.top = lis[i-1].style.top; // } for(var i=lis.length-1;i>0;i--){ lis[i].style.left = lis[i-1].style.left; lis[i].style.top = lis[i-1].style.top; } // 改變第一節 lis[0].style.left = left+'px'; lis[0].style.top = top+'px'; // console.log(food_top+'----------'); // console.log(top); if(left == food_left && top == food_top){ eat(); } } function eat() { $('js_bg').removeChild($('foodDiv')); js_food(); // alert('ll'); let li = document.createElement('li'); $('js_bg').appendChild(li); // create_snake(); }

更多關于JavaScript相關內容感興趣的讀者可查看本站專題:《JavaScript數學運算用法總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript數組操作技巧總結》、《JavaScript時間與日期操作技巧總結》及《JavaScript錯誤與調試技巧總結》

希望本文所述對大家JavaScript程序設計有所幫助。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 日韩区在线观看 | 1024色淫免费视频 | 色丁香久久 | 大学生一级一片第一次欧美 | 亚洲成人在线免费观看 | 日韩中文字幕免费观看 | 欧美成人国产一区二区 | 国产亚洲高清不卡在线观看 | 成人毛片免费免费 | 中文字幕天堂最新版在线网 | 特黄日韩免费一区二区三区 | 一本大道香蕉久在线不卡视频 | 99青青| 三级中文字幕 | 黄色国产网站 | 俄罗斯18videosex性欧美成人 | 日韩欧美综合在线二区三区 | 中文字幕一区中文亚洲 | 毛片在线视频在线播放 | 国产女人成人精品视频 | 久久久久欧美国产精品 | 久久精品网站免费观看 | 波多野结衣免费免费视频一区 | 沈樵在线观看福利 | 国产亚洲精品日韩已满十八 | 国产精品va一级二级三级 | 免费一级毛片在线播放视频 | 免费在线观看一区二区 | 久久久久久久久一次 | 美女黄视频网站 | 中文字幕精品一区二区三区视频 | 男女乱配视频免费观看 | 中文字幕福利 | 黄网站色视频免费观看w | 久久精品久久精品久久精品 | 国产一区二区在线播放 | 国产成人3p视频免费观看 | 在线一区播放 | 女仆色在线 | 欧美一区二区三区在线观看 | 国产成人精品久久一区二区三区 |