源码实现html贪吃蛇

HTML贪吃蛇源码实现

这段代码用到了jQuery, 注意代码里面引入的外部jQuery.js,可以自行去官网下载。

效果:

在这里插入图片描述
操作:上下左右键控制方向
源码:

<!DOCTYPE html>
<html>
 <head>
  <meta charset="utf-8">
  <title></title>
  <style>
   .div1{
    height:600px;
    width:900px;
    border:solid;
    background:green;
   }
   .snake{
    height:10px;
    width:10px;
    position: fixed; 
    top:100px;
    left:100px;
    border:solid;
    background:black;
   }
   .food{
    height:10px;
    width:10px;
    position: fixed;
    top:300px;
    left:400px;
    background:red;
   }
  </style>
  <script src="jquery-3.2.1.js"></script>
  <script>
   $(function(){
    var count=1;
    var sm=2000;//初始时速
    var extent=100;//初始长度
    function food(){//随机坐标产生食物
     while(true){
      let num1 = Math.floor(Math.random()*900);
      let num2 = Math.floor(Math.random()*600);
      if(num1>13 && num2>20){
       $("#food").offset({top:num2,left:num1});
       break;
      } 
     }
    }
    
    function die(){//触碰边缘死亡
     $(document).off('keydown');
     alert("死亡!!!");
    }
    
    function eat(sleft,stop){//计算两个盒子相撞证明snake eat到了food
     $("<div class='snake'></div>").appendTo($(".div1")).offset({top:stop,left:sleft}).fadeOut(extent,function(){$(this).remove()});
     let eatX = sleft - $("#food").offset().left;
     let eatY = stop - $("#food").offset().top;
     
     if(eatX<10 && eatX>-10 && eatY<10 && eatY>-15){
      food();//eat到food时调用food产生的方法
      sm-=50;//每eat到一个food将时速减少100sm
      extent+=50;
      $('span').text("得分:"+count++);
     }
    }
    
    
    $(document).keydown(function(event){//蛇的动作
     var keyNum = event.which;  //获取键值
     if(keyNum==37){//左
      $("#snake").stop();//用于切换方向时暂停之前的动作
      $("#snake").animate(
      {left:10},
      {
       duration: sm,
       step: function() {
        if($(this).offset().left<11){
         die();
        }
        eat($(this).offset().left,$(this).offset().top);
       }
      });
     }else if(keyNum==38){//上
      $("#snake").stop();
      $("#snake").animate(
      {top:27},
      {
       duration: sm,
       step: function() {
        if($(this).offset().top<28){
         die();
        }
        eat($(this).offset().left,$(this).offset().top);
       }
      });
     }else if(keyNum==39){//右
      $("#snake").stop();
      $("#snake").animate(
      {left:896},
      {
       duration: sm,
       step: function() {
        if($(this).offset().left>895){
         die();
        }
        eat($(this).offset().left,$(this).offset().top);
       }
      });
     }else if(keyNum==40){//下
      $("#snake").stop(); 
      $("#snake").animate(
      {top:615},
      {
       duration: sm,
       step: function() {
        if($(this).offset().top>614){
         die();
        }
        eat($(this).offset().left,$(this).offset().top);
       }
      });
     } 
    });
   
   });
  </script>
 </head>
 <body>
  <span>得分:</span>
  <div class="div1">
   <div id="snake" class="snake"><div>
   <div id="food" class="food"><div>
  </div>
</body>
</html>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值