亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > JavaScript > 正文

js編寫“貪吃蛇”的小游戲

2024-05-06 16:26:22
字體:
來源:轉載
供稿:網友
本文為大家介紹的是使用JS寫的貪吃蛇游戲,個人練習之用,感興趣的朋友可以參考下哈,希望對大家學習js有所幫助
 

貪吃蛇兒時的回憶,今天剛好學習到這了,就剛好做了一個,也是學習了吧,需要掌握的知識:

  1、JS函數的熟練掌握,

  2、JS數組的應用,

  3、JS小部分AJAX的學習

  4、JS中的splice、shift等一些函數的應用,

基本上就這些吧,下面提重點部分:
前端的頁面,這里可自行布局,我這邊提供一個我自己的布局:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">                     <head>  <meta http-equiv="Content-Type" content="text/html;charset=UTF-8">  <title>貪吃蛇</title>  <link rel="stylesheet" type="text/css" href="./css.css">  <script type="text/javascript" src="./jquery-1.7.2.min.js"></script>  <script type="text/javascript" src="./js.js"></script></head><body>  <div id="info">      <div id="score">0</div>    <form action="" id="form" name="form">      <input type="radio" name='time' value="500" checked='checked'/>簡單      <input type="radio" name='time' value="300"/>中等      <input type="radio" name='time' value="150"/>高級      <input type="radio" name='time' value="50"/>神速      <input type="button" value="開始" class="button" id="start"/>      <input type="button" value="重玩" class="button" id="res"/>     </form>       </div>  <div id="main">    <div id="home">      <!--<div style="background:url(./images/snake0.png) no-repeat;"></div>      <div style="background:url(./images/snake1.png) no-repeat; left:20px;"></div>      <div style="background:url(./images/snake2.png) no-repeat; left:40px;"></div>      <div style="background:url(./images/snake3.png) no-repeat; left:60px;"></div>-->    </div>    <div class="wall left"></div>    <div class="wall right"></div>    <div class="wall top"></div>    <div class="wall bottom"></div>  </div>                            </body> </html>

 這里是css代碼:

*{padding: 0px; margin: 0px;font-size: 12px}body{background: #ccc}input.button{  width: 60px;  cursor: pointer;}#info{  width: 540px;  height: 30px;  margin: 30px auto 5px;  line-height: 30px;}#score{  width: 73px;  height: 28px;  padding-left: 64px;  background: url(./images/score.png) no-repeat;  float: left;  font-size: 14px;  font-weight: 700;  font-style:italic;  font-family: '微軟雅黑';}#form{  float: right;}#form input{  vertical-align: middle;  margin-right: 5px;}#main{  width: 540px;  height: 500px;  margin: 0 auto;  position: relative;  /*background: #71a000*/ }#main div{  width: 20px;  height: 20px;  position: absolute;}#main #home{  width: 500px;  height: 460px;  left: 20px;  top: 20px;  position: relative;  background: url(./images/background.jpg) no-repeat;}#main #home div{  position: absolute;}#main div.wall{  width: 540px;  height: 20px;  background: url("./images/div.jpg") repeat-x;  position: absolute;}#main div.top{  left:0px;  top:0px;} #main div.bottom{  left:0px;  top:480px;}#main div.left{  width: 20px;  height: 500px;  background: url(./images/div.jpg) repeat-y;  left:0px;  top:0px;}#main div.right{  width: 20px;  height: 500px;  background: url(./images/div.jpg) repeat-y;  left:520px;  top:0px;} .l{  -moz-transform:rotate(0deg);    -o-transform:rotate(0deg);  -webkit-transform:rotate(0deg);  transform:rotate(0deg);  /* IE8+ - must be on one line, unfortunately */    -ms-filter: "progid:DXImageTransform.Microsoft.Matrix(M11=1, M12=0, M21=0, M22=1, SizingMethod='auto expand')";     /* IE6 and 7 */   filter: progid:DXImageTransform.Microsoft.Matrix(      M11=1,      M12=0,      M21=0,      M22=1,      SizingMethod='auto expand');}.t{  -moz-transform:  rotate(90deg);   -o-transform:   rotate(90deg);   -webkit-transform: rotate(90deg);   transform:     rotate(90deg);  /* IE8+ - must be on one line, unfortunately */  -ms-filter: "progid:DXImageTransform.Microsoft.Matrix(M11=-1.8369701987210297e-16, M12=-1, M21=1, M22=-1.8369701987210297e-16, SizingMethod='auto expand')";   /* IE6 and 7 */  filter: progid:DXImageTransform.Microsoft.Matrix(      M11=-1.8369701987210297e-16,      M12=-1,      M21=1,      M22=-1.8369701987210297e-16,      SizingMethod='auto expand'); }.r{  -moz-transform:  rotate(180deg);   -o-transform:   rotate(180deg);   -webkit-transform: rotate(180deg);   transform:     rotate(180deg);   /* IE8+ - must be on one line, unfortunately */  -ms-filter: "progid:DXImageTransform.Microsoft.Matrix(M11=-1, M12=1.2246467991473532e-16, M21=-1.2246467991473532e-16, M22=-1, SizingMethod='auto expand')";   /* IE6 and 7 */  filter: progid:DXImageTransform.Microsoft.Matrix(      M11=-1,      M12=1.2246467991473532e-16,      M21=-1.2246467991473532e-16,      M22=-1,      SizingMethod='auto expand'); }.b{  -moz-transform:  rotate(270deg);   -o-transform:   rotate(270deg);   -webkit-transform: rotate(270deg);   transform:     rotate(270deg);  /* IE8+ - must be on one line, unfortunately */  -ms-filter: "progid:DXImageTransform.Microsoft.Matrix(M11=6.123233995736766e-17, M12=1, M21=-1, M22=6.123233995736766e-17, SizingMethod='auto expand')";   /* IE6 and 7 */  filter: progid:DXImageTransform.Microsoft.Matrix(      M11=6.123233995736766e-17,      M12=1,      M21=-1,      M22=6.123233995736766e-17,      SizingMethod='auto expand');   }

JS公共文件

var home = $('#home');  var snakeArr = [];  var direcation = 'l';  var speed = 0;  var timer = '';  //460/20  var rows = 23;  var cols = 25;  var die = false;      //用于判斷是否game over  var food = [];  var sorce = 0;       //得分的顯示 

首先要想有snake就必須創造snake,

for( var i=0; i<4; i++ ){    //var snakeDiv = document.createElement("div");    //snakeDiv.style = 'background:url(./images/snake' + i + '.png) no-repeat;';    var snakeDiv = $('<div style="background:url(./images/snake' + i + '.png) no-repeat;z-index:999"></div>');    home.append(snakeDiv);    snakeArr[i] = {r : 10, c : 10 + i, div : snakeDiv, d : direcation};    setPosition(snakeArr[i]);   }

 有snake之后,自然就是移動了(move):

function move(){    var timer = setInterval(function(){    for( var i=snakeArr.length -1; i>0; i-- ){      snakeArr[i].c = snakeArr[i-1].c;      snakeArr[i].r = snakeArr[i-1].r;      snakeArr[i].d = snakeArr[i-1].d;      }       switch(direcation){      case 'l' :        snakeArr[0].c--;        snakeArr[0].d = 'l';        break;       case 'r' :        snakeArr[0].c++;        snakeArr[0].d = 'r';        break;       case 't' :        snakeArr[0].r--;        snakeArr[0].d = 't';        break;       case 'b' :        snakeArr[0].r++;        snakeArr[0].d = 'b';        break;    }     //snake的方向控制    $(window).keydown(function(event){      switch(event.keyCode){        case 37 :          direcation = 'l';          break;         case 38 :          direcation = 't';          break;         case 39 :          direcation = 'r';          break;         case 40 :          direcation = 'b';          break;      }    });       //snake事故      //1. snake撞墻      if( snakeArr[0].c < 0 || snakeArr[0].r < 0 || snakeArr[0].c >= cols || snakeArr[0].r >= rows ){          clearInterval(timer);          die = true;          alert('GAME OVER');      }       //2. snake撞到自己      for( var i=1; i<snakeArr.length; i++ ){        if( snakeArr[0].c == snakeArr[i].c && snakeArr[0].r == snakeArr[i].r ){           clearInterval(timer);           die = true;           alert('GAME OVER');        }      }       //snake吃水果      if( snakeArr[0].c == food[0].c && snakeArr[0].r == food[0].r ){        food[0].div.css({background : 'url(./images/snake2.png) no-repeat'});        snakeArr.splice(snakeArr.length - 1, 0, food[0]);        food.shift();        sorce += 10;        $('#score').html(sorce);      }       //snake產生水果      if( food.length == 0 ){        createFood();       }        for(var i = 0; i < snakeArr.length; i++){        setPosition(snakeArr[i]);      }    },speed); }

食物的產生:

function createFood(){    var r = parseInt(rows * Math.random());    var c = parseInt(cols * Math.random());    var casrsh = false;         //2個水果出現的位置不能一樣    while( food.length == 0 ){      //判斷snake的位置,不能與snake相撞      for( var i = 0; i < snakeArr.length; i++ ){        if( r == snakeArr[i].r && c == snakeArr[i].c ){          casrsh = true;        }      }      //當位置不重疊的時候,產生水果      if( !casrsh ){        var i = parseInt(4 * Math.random());        var foodDiv = $('<div style="background:url(./images/fruit'+ i +'.png);"></div>');        home.append(foodDiv);        food.push({r : r, c : c, div : foodDiv});        setPosition(food[0]);      }    }       } 

 還有一個重要的功能就是重新設置定位:

function setPosition(obj){    obj.div.css({left : obj.c * 20, top : obj.r * 20});     obj.div.removeClass().addClass(obj.d);  }  createFood();  //那頁面一被加載出來就顯示出食物! 

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



注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91久久国产精品91久久性色| 91欧美精品成人综合在线观看| 国产精品久久久久久久久久ktv| 亚洲在线免费视频| 精品偷拍一区二区三区在线看| 国产精品免费久久久| 久久97久久97精品免视看| 欧美有码在线视频| 美女av一区二区三区| 高清欧美一区二区三区| 好吊成人免视频| 欧美性极品xxxx娇小| 亚洲国产精品久久| 成人免费xxxxx在线观看| 亚洲一区二区国产| 亚洲欧美在线一区二区| 欧美情侣性视频| 国产精品jizz在线观看麻豆| 精品亚洲一区二区三区在线观看| 色偷偷av亚洲男人的天堂| 欧美www在线| 国产一区玩具在线观看| 国产精品福利无圣光在线一区| 亚洲自拍偷拍色片视频| 欧美www在线| 欧美一级视频免费在线观看| 中文字幕亚洲自拍| 91国产高清在线| 国产精品青草久久久久福利99| 欧美性猛xxx| 日本aⅴ大伊香蕉精品视频| 久久久久久久久久国产| 国产精品观看在线亚洲人成网| 日韩av在线免费看| 成人黄色av免费在线观看| 91中文字幕在线观看| 欧美国产第一页| 久久久999精品免费| 国产视频在线一区二区| 91精品国产自产在线观看永久| 久久久av网站| 欧美巨大黑人极品精男| 日韩精品视频在线免费观看| 久久久久久噜噜噜久久久精品| 97在线视频免费| 91精品国产91久久久久久吃药| 高潮白浆女日韩av免费看| 国产成人精品电影| 日韩av大片在线| 久久精品一区中文字幕| 精品国产电影一区| 综合国产在线观看| 欧美贵妇videos办公室| 亚洲日韩欧美视频| 色综久久综合桃花网| 亚洲欧美日本伦理| 亚洲国产精品va在线| 欧美丝袜第一区| 国产精品视频99| 国产精品久久久久免费a∨大胸| 欧美另类极品videosbestfree| 亚洲国产欧美一区二区三区同亚洲| 国产精品久久一区| 欧美在线性视频| 日韩av在线影院| 大胆人体色综合| 国产精品美女www爽爽爽视频| 欧美日韩成人在线观看| 亚洲片在线观看| 国产精品极品美女粉嫩高清在线| 在线成人免费网站| 91中文字幕在线| 亚洲精品自在久久| 亚洲欧美激情视频| 国产在线久久久| 亚洲韩国青草视频| 久久精品免费播放| 国产精品r级在线| 久久69精品久久久久久久电影好| 亚洲欧洲偷拍精品| 久久精品2019中文字幕| 久久久综合免费视频| 成人黄色中文字幕| 69视频在线播放| 性色av一区二区三区红粉影视| 国产成人精品久久亚洲高清不卡| 91国产在线精品| 日韩精品极品视频免费观看| 日韩欧美中文字幕在线观看| 久久精品成人欧美大片古装| 亚洲a∨日韩av高清在线观看| 欧美日韩成人黄色| 国产精品视频精品视频| 精品少妇一区二区30p| 欧美日韩激情视频| 搡老女人一区二区三区视频tv| 色中色综合影院手机版在线观看| 久久精品影视伊人网| 久久天天躁狠狠躁夜夜av| 欧美电影在线观看| 91在线无精精品一区二区| 国产精品专区h在线观看| 国产成人亚洲综合91精品| 欧美黑人狂野猛交老妇| 亚洲第一福利网站| 国自在线精品视频| 日韩欧美aⅴ综合网站发布| 国产美女久久久| 成人黄色午夜影院| 欧美日本中文字幕| 亚洲欧美日韩国产中文| 97久久精品人人澡人人爽缅北| 亚洲成人在线视频播放| 一区二区三区视频免费| 成人黄色免费在线观看| 亚洲精品wwww| 7m第一福利500精品视频| 琪琪亚洲精品午夜在线| 国产视频一区在线| 日韩精品视频免费专区在线播放| 亚洲日韩中文字幕| 欧美天天综合色影久久精品| 成人精品视频99在线观看免费| 精品视频久久久久久久| 欧美成人免费一级人片100| 精品高清一区二区三区| 激情懂色av一区av二区av| www.久久撸.com| 亚洲人成电影在线| 亚洲一区二区三区四区视频| 欧美资源在线观看| 久久久精品2019中文字幕神马| 亚洲成人精品在线| 亚洲加勒比久久88色综合| 69国产精品成人在线播放| 韩剧1988在线观看免费完整版| 欧美高清视频一区二区| 欧洲美女免费图片一区| 中文字幕久久久| 亚洲欧美日韩国产中文专区| 97超级碰在线看视频免费在线看| 奇门遁甲1982国语版免费观看高清| 国产视频精品自拍| 久久99亚洲精品| 欧美插天视频在线播放| 久久久久久伊人| 国产欧美最新羞羞视频在线观看| 欧洲美女7788成人免费视频| 国产日韩在线播放| 日韩精品中文字幕视频在线| 国产精品日韩精品| 久久精品91久久久久久再现| 亚洲va久久久噜噜噜| 欧美激情一区二区久久久| 久久久极品av| 国产精品国产福利国产秒拍| 亚洲欧美精品在线| 欧美在线视频观看| 日韩高清中文字幕| 成人字幕网zmw| 国产乱肥老妇国产一区二| 中文字幕在线观看日韩| 国产精品一区二区三区免费视频| 欧美激情精品久久久久久免费印度|