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

首頁 > 編程 > JavaScript > 正文

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

2019-11-20 11:01:07
字體:
來源:轉載
供稿:網友

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

  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程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91久久夜色精品国产网站| 亚洲欧美国产另类| 久久国产视频网站| 日韩电影在线观看永久视频免费网站| 欧美成aaa人片在线观看蜜臀| 日韩国产高清视频在线| 日韩大陆毛片av| 久久久999国产| 久久夜色精品国产欧美乱| 国产精品免费久久久久影院| 欧美最近摘花xxxx摘花| 成人有码视频在线播放| 在线播放精品一区二区三区| 国产精品久久久亚洲| 国产精品夫妻激情| 红桃视频成人在线观看| 欧美一级片免费在线| 欧日韩在线观看| 午夜精品国产精品大乳美女| 91亚洲永久免费精品| 久久中文字幕一区| 欧美精品电影在线| 日韩精品电影网| 精品国产户外野外| 国产成人精品免费久久久久| 日本19禁啪啪免费观看www| 国产ts人妖一区二区三区| 国产精品r级在线| 91精品久久久久久久久久入口| 国产精品一区二区三| 日本人成精品视频在线| 国产精品福利久久久| 国模精品视频一区二区三区| 国产日韩视频在线观看| 精品一区二区三区四区在线| 欧美在线观看网址综合| 这里只有精品视频在线| 91国偷自产一区二区三区的观看方式| 国产成人精品一区二区三区| 日韩亚洲欧美成人| 亚洲人成亚洲人成在线观看| 在线播放日韩专区| 欧美肥老太性生活视频| 亚洲一区二区三区视频播放| 日本一区二区在线播放| 亚洲成人久久一区| 欧美精品日韩三级| 热99久久精品| 久久久国产精品一区| 福利视频导航一区| 精品日韩视频在线观看| 国产视频一区在线| 国产精品成人免费视频| 久久久97精品| 国产日韩在线视频| 久久天天躁狠狠躁夜夜躁2014| 精品无码久久久久久国产| 欧美韩国理论所午夜片917电影| 国产精品com| 欧美性xxxx极品hd欧美风情| 亚洲综合视频1区| 欧美精品videosex极品1| 日韩精品高清在线观看| 久久久久久中文| 色www亚洲国产张柏芝| 狠狠色狠狠色综合日日小说| 午夜美女久久久久爽久久| 亚洲一区二区三区香蕉| 91在线观看免费网站| 亚洲精品www久久久久久广东| 欧美性猛交xxxx免费看久久久| 国产999精品| 91精品啪aⅴ在线观看国产| 国产色婷婷国产综合在线理论片a| 精品动漫一区二区| 欧美极品少妇xxxxⅹ免费视频| 色诱女教师一区二区三区| 成人免费视频97| 91九色单男在线观看| 国产一区二区三区久久精品| 欧美最猛性xxxx| 69av在线播放| 欧美性猛交xxxx乱大交蜜桃| 欧美性猛交xxxx富婆弯腰| 成人免费淫片视频软件| 26uuu另类亚洲欧美日本老年| 久久视频在线免费观看| 久久精品视频99| 91大神福利视频在线| 欧美乱人伦中文字幕在线| 91国自产精品中文字幕亚洲| 色综合91久久精品中文字幕| 主播福利视频一区| 福利视频一区二区| 亚洲视频欧美视频| 亚洲va电影大全| 一区二区亚洲欧洲国产日韩| 911国产网站尤物在线观看| 日韩成人激情影院| 97在线免费观看视频| 亚洲一区二区黄| 亚洲精品自拍视频| 国产精品视频中文字幕91| 91热福利电影| 欧美精品在线免费观看| 亚洲第一网站免费视频| 色悠悠久久88| 欧美疯狂做受xxxx高潮| 国产在线观看精品一区二区三区| 国产成人亚洲综合青青| 成人午夜黄色影院| 欧美另类在线播放| 在线日韩av观看| 久久久久久久一区二区三区| 国产999精品视频| 成人免费网站在线看| 美日韩丰满少妇在线观看| 亚洲福利在线观看| 国产精品视频在线观看| 亚洲国产精品久久久久久| 青青草原一区二区| 黑人巨大精品欧美一区二区免费| 久久在线免费视频| 日本高清+成人网在线观看| 久久久精品国产| 久久精品视频在线| 欧美做受高潮电影o| 中文字幕av日韩| 精品香蕉一区二区三区| 欧美xxxx做受欧美| 庆余年2免费日韩剧观看大牛| 日韩av电影中文字幕| 国产精品18久久久久久首页狼| 成人网址在线观看| 日本高清不卡的在线| 黑人巨大精品欧美一区二区一视频| 国产精品一香蕉国产线看观看| 人九九综合九九宗合| 欧美福利视频在线观看| 92福利视频午夜1000合集在线观看| 国产精品一区二区三区免费视频| 国产精品999| 欧美—级a级欧美特级ar全黄| 中文日韩在线观看| 久久精品国产91精品亚洲| 亚洲国内高清视频| 中文字幕日本欧美| 亚洲欧美日韩中文在线制服| 国产精品91在线| 欧美资源在线观看| 国产91色在线免费| 国产日韩一区在线| 成人免费自拍视频| 亚洲免费视频观看| 国产欧美久久一区二区| 国产91色在线| 一区二区三区四区在线观看视频| 欧美在线视频一二三| 欧美黄网免费在线观看| 色爱精品视频一区| 亚洲欧美日韩久久久久久| 久久视频精品在线| 91精品国产综合久久男男| 国产精品精品久久久久久|