文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

JavaScript怎么实现网页贪吃蛇游戏

2023-06-20 17:43

关注

小编给大家分享一下JavaScript怎么实现网页贪吃蛇游戏,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

具体内容如下

<!DOCTYPE html><html><head><title>贪吃蛇</title></head><body><canvas id="canvas" width="400" height="400"></canvas><script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.0/jquery.js"></script><script>var canv=document.getElementById("canvas");var ctx=canv.getContext("2d");var score=0;//定义一个方块的构造函数var Block=function(col,row,size){  this.col=col;  this.row=row;  this.size=size;    };//定义Block函数的原型方法draw;Block.prototype.draw =function(){  ctx.fillRect(this.col*this.size,this.row*this.size,this.size,this.size)   }//定义对象蛇var snake ={  body:[    new Block(20,20,10),    new Block(20,21,10),    new Block(20,22,10)   ],  direction:"right",  };//定义画蛇的函数snake.draw=function(){   for(var i=0;i<this.body.length;i++)  {     this.body[i].draw();        }   };snake.move = function()         {          var head = this.body[0];if(snake.direction=="right")     {         var newhead=new Block(head.col+1,head.row,head.size)            }    if(snake.direction =="left")        {      var newhead = new Block(head.col-1,head.row,head.size);            }   if(snake.direction=="up")     {     var newhead=new Block(head.col,head.row-1,head.size)           }    if(snake.direction=="down")     {     var newhead=new Block(head.col,head.row+1,head.size)           }           if(newhead.col<0 || newhead.col>39 )          {           clearInterval(intervalId);           gameover();          }                    if(newhead.row<0 || newhead.row>39 )          {           clearInterval(intervalId);           gameover();          } for(var i=0;i<this.body.length;i++){    if(this.body[i].col==newhead.col &&this.body[i].row==newhead.row)  {    clearInterval(intervalId);    gameover();      }          }              this.body.unshift(newhead);     if(newhead.col==apple.posX &&newhead.row==apple.posY){      score=score+100;    while(true)  {     var checkApple =false;     apple.posX=Math.floor(Math.random()*40);     apple.posY=Math.floor(Math.random()*40);     for(var i=0; i<this.body.length;i++)   {     if(this.body[i].col==apple.posX &&this.body[i].row==apple.posY)          checkApple=true;                        }       if(!checkApple)       break;      }    }else{     this.body.pop();        }                  };//创建苹果对象var apple={    posX:Math.floor(Math.random()*40),    posY:Math.floor(Math.random()*40),    sizeR:5}//画苹果函数apple.draw=function(){  ctx.fillStyle="Green";  ctx.beginPath();  ctx.arc(this.posX*10+5,this.posY*10+5,5,0,Math.PI*2,false);  ctx.fill();  ctx.fillStyle="Black";     };//结束var gameover=function(){  ctx.font="60px Comic Sans MS";  ctx.textAlign="center";  ctx.textBaseline="middle";  ctx.fillText("GAME OVER!",200,200)    };//定时功能var intervalId=setInterval (function (){   ctx.clearRect(0,0,400,400);   ctx.font="20px Arial";   ctx.fillText("Score:"+score,5,15);   snake.draw();   snake.move();   apple.draw();   ctx.strokeRect(0,0,400,400);    },200);//贪吃蛇的按键控制$("body").keydown(function(event){   console.log(event.keyCode);    if(event.keyCode==37 &&snake.direction!="right")     {    snake.direction="left";         }    if(event.keyCode==38 &&snake.direction!="down")     {    snake.direction="up";        }    if(event.keyCode==39 &&snake.direction!="left")     {     snake.direction="right";         }     if(event.keyCode==40 &&snake.direction!="up")     {     snake.direction="down";         }              });</script></body></html>

JavaScript怎么实现网页贪吃蛇游戏

以上是“JavaScript怎么实现网页贪吃蛇游戏”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网行业资讯频道!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯