电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

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

瀏覽:96日期: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
相關文章:
主站蜘蛛池模板: 广州网站建设_小程序开发_番禺网站建设_佛山网站建设_粤联网络 | 危废处理系统,水泥厂DCS集散控制系统,石灰窑设备自动化控制系统-淄博正展工控设备 | 宿舍管理系统_智慧园区系统_房屋/房产管理系统_公寓管理系统 | 双能x射线骨密度检测仪_dxa骨密度仪_双能x线骨密度仪_品牌厂家【品源医疗】 | 瑞典Blueair空气净化器租赁服务中心-专注新装修办公室除醛去异味服务! | 自动气象站_气象站监测设备_全自动气象站设备_雨量监测站-山东风途物联网 | 龙门加工中心-数控龙门加工中心厂家价格-山东海特数控机床有限公司_龙门加工中心-数控龙门加工中心厂家价格-山东海特数控机床有限公司 | 熔体泵|换网器|熔体齿轮泵|熔体计量泵厂家-郑州巴特熔体泵有限公司 | 云南成考网_云南成人高考报名网| 国产离子色谱仪,红外分光测油仪,自动烟尘烟气测试仪-青岛埃仑通用科技有限公司 | 钢格板_钢格栅_格栅板_钢格栅板 - 安平县鑫拓钢格栅板厂家 | 武汉森源蓝天环境科技工程有限公司-为环境污染治理提供协同解决方案 | 辐射仪|辐射检测仪|辐射巡测仪|个人剂量报警仪|表面污染检测仪|辐射报警仪|辐射防护网 | 捆扎机_气动捆扎机_钢带捆扎机-沈阳海鹞气动钢带捆扎机公司 | 施工电梯_齿条货梯_烟囱电梯_物料提升机-河南大诚机械制造有限公司 | 解放卡车|出口|济南重汽|报价大全|山东三维商贸有限公司 | 智能终端_RTU_dcm_北斗星空自动化科技 | 二氧化碳/活性炭投加系统,次氯酸钠发生器,紫外线消毒设备|广州新奥 | 防火阀、排烟防火阀、电动防火阀产品生产销售商-德州凯亿空调设备有限公司 | 一体式钢筋扫描仪-楼板测厚仪-裂缝检测仪-泰仕特(北京) | 定制异形重型钢格栅板/钢格板_定做踏步板/排水沟盖板_钢格栅板批发厂家-河北圣墨金属制品有限公司 | 密集柜_档案密集柜_智能密集架_密集柜厂家_密集架价格-智英伟业 密集架-密集柜厂家-智能档案密集架-自动选层柜订做-河北风顺金属制品有限公司 | 上海乾拓贸易有限公司-日本SMC电磁阀_德国FESTO电磁阀_德国FESTO气缸 | 福兰德PVC地板|PVC塑胶地板|PVC运动地板|PVC商用地板-中国弹性地板系统专业解决方案领先供应商! 福建成考网-福建成人高考网 | 有声小说,听书,听小说资源库-听世界网 | 液晶拼接屏厂家_拼接屏品牌_拼接屏价格_监控大屏—北京维康 | 电缆接头_防水接头_电缆防水接头_防水电缆接头_上海闵彬 | 武汉高低温试验机-现货恒温恒湿试验箱-高低温湿热交变箱价格-湖北高天试验设备 | 直流电能表-充电桩电能表-导轨式电能表-智能电能表-浙江科为电气有限公司 | 百方网-百方电气网,电工电气行业专业的B2B电子商务平台 | 球盟会·(中国)官方网站| ◆大型吹塑加工|吹塑加工|吹塑代加工|吹塑加工厂|吹塑设备|滚塑加工|滚塑代加工-莱力奇塑业有限公司 | 上海冠顶工业设备有限公司-隧道炉,烘箱,UV固化机,涂装设备,高温炉,工业机器人生产厂家 | CPSE安博会 | HYDAC过滤器,HYDAC滤芯,现货ATOS油泵,ATOS比例阀-东莞市广联自动化科技有限公司 | 污水处理设备维修_污水处理工程改造_机械格栅_过滤设备_气浮设备_刮吸泥机_污泥浓缩罐_污水处理设备_污水处理工程-北京龙泉新禹科技有限公司 | HEYL硬度计量泵-荧光法在线溶解氧仪-净时测控技术(上海)有限公司 | 称重传感器,测力传感器,拉压力传感器,压力变送器,扭矩传感器,南京凯基特电气有限公司 | 国产液相色谱仪-超高效液相色谱仪厂家-上海伍丰科学仪器有限公司 | 金属清洗剂,防锈油,切削液,磨削液-青岛朗力防锈材料有限公司 | 江苏齐宝进出口贸易有限公司|