溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

怎么用JavaScript寫個(gè)貪吃蛇小游戲

發(fā)布時(shí)間:2022-05-07 14:16:18 來源:億速云 閱讀:130 作者:iii 欄目:大數(shù)據(jù)

今天小編給大家分享一下怎么用JavaScript寫個(gè)貪吃蛇小游戲的相關(guān)知識(shí)點(diǎn),內(nèi)容詳細(xì),邏輯清晰,相信大部分人都還太了解這方面的知識(shí),所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

我們先把dom結(jié)構(gòu)寫出來

<div id="content">
      <div id="snake">
          <div class="box head"></div>
          <div class="box"></div>

      </div>
  
    </div>

其中,content為整個(gè)布局的大盒子,snake就是蛇,里面的box就是他的身體,為了區(qū)分頭部我們給第一個(gè)box加了個(gè)head名字用于區(qū)分,下面我們再把css加上

<style>
    .box{
      width: 60px;
      height: 60px;
      background-color: red;
      position:absolute;
      left: 0;
      top: 0;
      line-height: 60px;
    }
    .head{
      background-color: yellowgreen;
    }
  </style>

我們給蛇的每一節(jié)的寬高設(shè)置為60像素,并給了一個(gè)定位,因?yàn)槿绻患佣ㄎ坏脑挓o法讓他脫離文檔流(在頁面中飄起來),而且后續(xù)也無法通過left和top來判斷他的坐標(biāo).

怎么用JavaScript寫個(gè)貪吃蛇小游戲

好的這樣我們就得到了一條可愛的小蛇(然鵝并沒有看出來哪里可愛- -)。什么?你問我他的頭哪去了,很簡單,在給元素加了定位以后后面的元素會(huì)覆蓋掉前面的元素,所以只是頭部和身體重疊了你看不到而已。
隨后咱們得讓這條蛇動(dòng)起來是吧,那么我們怎么讓他動(dòng)起來呢?原理很簡單,我們可以設(shè)置一個(gè)定時(shí)器,每過一個(gè)時(shí)間就讓他動(dòng)一下,而怎么讓他動(dòng)呢,只需要設(shè)置一個(gè)數(shù)值,讓這個(gè)值每動(dòng)一下就+=60,然后通過判斷是上下動(dòng)還是左右動(dòng),來給元素的left與top賦值。我們把邏輯寫成代碼,就出來了如下的代碼

<script>
    var boxs = document.querySelectorAll(".box");
    var snake_x = 0;
    var snake_y = 0;
    var turn  = "right";
    setInterval(function(){
      snakeMove();
    },100)
    function snakeMove(){ 
      switch( turn ){
        case "right": snake_x += 60;break;
        case "left" : snake_x -= 60;break;
        case "top"  : snake_y -= 60;break;
        case "bottom": snake_y += 60;break;
      }

      for(var i = boxs.length - 1; i > 0 ; i --){
        boxs[i].style.left = boxs[i - 1].style.left;
        boxs[i].style.top = boxs[i - 1].style.top;
        
      }
      boxs[i].style.left = snake_x + "px";
      boxs[i].style.top = snake_y + "px";

    }
document.onkeydown = function(evt){
      var e = evt || event;
      var keyCode = e.keyCode || e.which;
      switch( keyCode ){
        case 37 : turn = "left";break;
        case 38 : turn = "top";break;
        case 39 : turn = "right";break;
        case 40 : turn = "bottom";break;
      }
    }

</script>

上述代碼中,我們給小蛇的初始位置的x和y的坐標(biāo)都設(shè)置為0,并且默認(rèn)初始向右走,通過鍵盤上方向鍵的輸入,來改變他的方向。其中,難點(diǎn)在于

for(var i = boxs.length - 1; i > 0 ; i --){
        boxs[i].style.left = boxs[i - 1].style.left;
        boxs[i].style.top = boxs[i - 1].style.top;
        
      }
      boxs[i].style.left = snake_x + "px";
      boxs[i].style.top = snake_y + "px";

這一塊代碼,這塊代碼的目的是讓后面的元素跟著前面的走,也就是讓蛇的每一塊身體都跟著上一塊去運(yùn)動(dòng),然后最后再給頭部設(shè)置為snake_x和snake_y當(dāng)前的值即可,這樣就形成了第一塊(頭部)坐標(biāo)為
snake_x,snake_y實(shí)時(shí)變化的值,第二塊為第一塊之前的值,第三塊為第二塊之前的值。。。以此類推就得到了一個(gè)身體跟著頭部走的效果

怎么用JavaScript寫個(gè)貪吃蛇小游戲

但是當(dāng)你把代碼輸進(jìn)去以后一運(yùn)行會(huì)發(fā)現(xiàn),這條小蛇過于頑皮,以至于走到邊界以后還會(huì)無限的向前走,那這不行啊,總不能讓蛇跑了不是,所以得給小蛇加上一個(gè)邊界

  var snake_x_max = document.documentElement.clientWidth ;
    var snake_y_max = document.documentElement.clientHeight;
if(snake_x > snake_x_max){
        snake_x = 0;
      }
      if(snake_x < 0){
        snake_x = snake_x_max;
      }
      if(snake_y > snake_y_max){
        snake_y = 0;
      }
      if(snake_y < 0){
        snake_y = snake_y_max;
      }

這里我們設(shè)置x和y的最大值為當(dāng)前窗口的寬高,然后通過if語句進(jìn)行判斷,如果當(dāng)前坐標(biāo)大于了最大值,就講當(dāng)前坐標(biāo)歸0,如果小于0的話(也就是跑到了左邊的邊界),就將當(dāng)前坐標(biāo)設(shè)置為最大值,這樣就可以得到一個(gè)邊界啦

怎么用JavaScript寫個(gè)貪吃蛇小游戲

你以為這樣就完事啦?nonono,沒有食物吃的蛇怎么能叫做貪吃蛇呢,那是沒有靈魂噠。下面我們開始制作食物(不能讓蛇餓著是吧)。

<div id="food">
  
      </div>

然后給他加個(gè)css

#food{
    width: 60px;
    height: 60px;
    position: absolute;
    background: greenyellow;
  }

然后再綁定一下元素并將他的left和top值設(shè)為范圍內(nèi)隨機(jī)數(shù),這樣可以做到隨機(jī)位置生成

var fd=document.getElementById("food");
    fd.style.left=Math.random()*snake_x_max+"px";
    fd.style.top=Math.random()*snake_y_max+"px";

好的這樣我們就得到了一個(gè)隨機(jī)生成的食物

怎么用JavaScript寫個(gè)貪吃蛇小游戲

不過我們的小蛇好像對食物并沒有什么興趣呢,路過以后并不會(huì)吃掉,所以我們得給他加一個(gè)碰撞檢測吧,碰撞檢測的邏輯很簡單,只需要讓食物的left值與頭部的left值相減的絕對值<=食物的大小,并且食物的top值與頭部的top值相減的絕對值<=食物的大小,設(shè)置小于等于是因?yàn)槿绻苯佑孟嗟葋砼袛嗟脑?,必須兩個(gè)元素完全重合才行,我們需要的是碰到邊緣就算遲到,所以用兩個(gè)數(shù)值相減小于等于來做。然后判斷當(dāng)頭部與食物發(fā)生碰撞時(shí),將蛇的身體部分克隆一塊出來放到蛇的身體里面,并讓食物的位置重新刷新(適用克隆為偷懶方法,此偷懶方法僅適用于當(dāng)小蛇開局自帶一個(gè)身體的時(shí)候,如果小蛇開局不自帶身體的話,我們無法克隆已有身體,只能通過createElement去新創(chuàng)建一個(gè)身體塊出來并添加className后再添加到父元素中去才行)。下面我們把邏輯轉(zhuǎn)換為代碼

var dl=snake_x;
    var dt=snake_y;
    var fl=fd.style.left;
    var ft=fd.style.top;
    var dv=document.querySelectorAll("#snake div");
    var sk=document.getElementById("snake");
    var a2=Number(fl.substring(0,fl.indexOf("px")));
    var b2=Number(ft.substring(0,ft.indexOf("px")));
    if(Math.abs(dl-a2)<=60&&Math.abs(dt-b2)<=60){
       fd.style.left=Math.random()*1000+"px";
       fd.style.top=Math.random()*800+"px";
       sk.appendChild(dv[1].cloneNode());
       boxs = document.querySelectorAll(".box");
    }

其中那一大長串的substring的方法是因?yàn)楂@取到的left與top的值的格式是例如”200px”這樣的數(shù)組,無法進(jìn)行數(shù)學(xué)運(yùn)算,所以要把px給截掉,并將剩下的字符串”200”轉(zhuǎn)換成number類型才可以進(jìn)行數(shù)學(xué)運(yùn)算。

怎么用JavaScript寫個(gè)貪吃蛇小游戲

以上就是“怎么用JavaScript寫個(gè)貪吃蛇小游戲”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會(huì)為大家更新不同的知識(shí),如果還想學(xué)習(xí)更多的知識(shí),請關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI