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

首頁 > 編程 > JavaScript > 正文

原生js實現的貪吃蛇網頁版游戲完整實例

2019-11-20 12:27:05
字體:
來源:轉載
供稿:網友

本文實例講述了原生js實現的貪吃蛇網頁版游戲。分享給大家供大家參考。具體實現方法如下:

<html><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><title>原生js寫的貪吃蛇網頁版游戲</title></head><body></body><script> Star = {init:function(){var bigDiv = this.appendEle(this.addStyle(this.creatEle(),{w:'900',h:'600',p:'absolute',t:10,l:500}));for(var i = 0; i<600/30;i++){Star.data.arrayAll[i] = [];for(var j = 0; j<900/30; j++){div = this.addStyle(this.creatEle(),{w:(!+[1,] ? 30 :28),h:(!+[1,] ? 30 :28),f:'left',border:'1px solid #666'});div.setAttribute('number', i*30+j)this.appendEle(div,bigDiv)Star.data.arrayAll[i][j] = div;}}bigDiv = this.appendEle(this.addStyle(this.creatEle(),{w:'900',h:'600',p:'absolute',t:10,l:500}));this.pushEleInSelect(Star.data.arrayAll[9][15],Star.data.arrayAll[9][14],Star.data.arrayAll[9][13])this.keyBoard.apply(this,arguments);this.appearPoint();this.leftGo();},appearPoint:function(){var arrayIn = [];var number;for(var i = 0; i<600; i++){if(!this.hasInArray(Star.data.arrayAll[parseInt(i/30)][i%30].getAttribute('number'),Star.data.arraySelect)){arrayIn.push(Star.data.arrayAll[i])}}Star.data.foodNumber = number = parseInt(Math.random()*arrayIn.length);this.giveColor(number)},giveColor:function(number){var div = Star.data.arrayAll[parseInt(number/30)][number%30];Star.timeInterval.timeB = setInterval(function(){if(div.className == 'shanshuo'){div.className = ''div.style.backgroundColor = '#fff'}else{div.className = 'shanshuo';div.style.backgroundColor = '#f00'}},500)},disappearColor:function(){clearInterval(Star.timeInterval.timeB);Star.data.arrayAll[parseInt(Star.data.foodNumber/30)][Star.data.foodNumber%30].style.backgroundColor = '#f00';},hasInArray:function(number,array){for(var i in array){if(array[i] instanceof Array){if(this.hasInArray(number,array[i])){return true;}}if(array[i].getAttribute && array[i].getAttribute('number') == number) return true;}return false;},keyBoard:function(){var self = this;document.onkeydown = function(e){e = e? e : window.event;switch(e.keyCode){case 37: if(Star.keycode == 37 || Star.keycode == 39){return;}; self.leftGo(); break;case 38: if(Star.keycode == 38 || Star.keycode == 40){return;}; self.upGo();break;case 39: if(Star.keycode == 37 || Star.keycode == 39){return;}; self.rightGo();break;case 40: if(Star.keycode == 38 || Star.keycode == 40){return;}; self.downGo();break;}}},leftGo:function(){var div, number , self = this;Star.keycode = 37;clearInterval(Star.timeInterval.timeA)Star.timeInterval.timeA = setInterval(function(){number = Star.data.arraySelect[0].getAttribute('number');if(number%30<=0 || self.hasInArray(number-1,Star.data.arraySelect)){self.guanle();}else{if(Star.data.foodNumber == number-1){self.pushEleInSelect(Star.data.arrayAll[parseInt(Star.data.foodNumber/30)][Star.data.foodNumber%30]);self.disappearColor();self.appearPoint();}else{div = Star.data.arraySelect.pop();div.style.background = '#fff';self.pushEleInSelect(Star.data.arrayAll[parseInt(number/30)][number%30-1]);}}},Star.timeInterval.speed)},upGo:function(){var div, number , self = this;Star.keycode = 38;clearInterval(Star.timeInterval.timeA)Star.timeInterval.timeA = setInterval(function(){number = parseInt(Star.data.arraySelect[0].getAttribute('number'));if(parseInt(number/30)<=0 || self.hasInArray(number-30,Star.data.arraySelect)){self.guanle();}else{if(Star.data.foodNumber == number-30){self.pushEleInSelect(Star.data.arrayAll[parseInt(Star.data.foodNumber/30)][Star.data.foodNumber%30]);self.disappearColor();self.appearPoint();}else{div = Star.data.arraySelect.pop();div.style.background = '#fff';self.pushEleInSelect(Star.data.arrayAll[parseInt(number/30)-1][number%30]);}}},Star.timeInterval.speed)},rightGo:function(){var div, number , self = this;Star.keycode = 39;clearInterval(Star.timeInterval.timeA)Star.timeInterval.timeA = setInterval(function(){number = parseInt(Star.data.arraySelect[0].getAttribute('number'));if(parseInt(number%30)>=29 || self.hasInArray(number+1,Star.data.arraySelect)){self.guanle();}else{if(Star.data.foodNumber == number+1){self.pushEleInSelect(Star.data.arrayAll[parseInt(Star.data.foodNumber/30)][Star.data.foodNumber%30]);self.disappearColor();self.appearPoint();}else{div = Star.data.arraySelect.pop();div.style.background = '#fff';self.pushEleInSelect(Star.data.arrayAll[parseInt(number/30)][number%30+1]);}}},Star.timeInterval.speed)},downGo:function(){var div, number , self = this;Star.keycode = 40;clearInterval(Star.timeInterval.timeA)Star.timeInterval.timeA = setInterval(function(){number = parseInt(Star.data.arraySelect[0].getAttribute('number'));if(parseInt(number/30)>=19 || self.hasInArray(number+30,Star.data.arraySelect)){self.guanle();}else{if(Star.data.foodNumber == number+30){self.pushEleInSelect(Star.data.arrayAll[parseInt(Star.data.foodNumber/30)][Star.data.foodNumber%30]);self.disappearColor();self.appearPoint();}else{div = Star.data.arraySelect.pop();div.style.background = '#fff';self.pushEleInSelect(Star.data.arrayAll[parseInt(number/30)+1][number%30]);}}},Star.timeInterval.speed)},guanle:function(){alert('撞墻了,總分:' + (Star.data.arraySelect.length-3) * parseInt(1000 / Star.timeInterval.speed));location.reload();},creatEle:function(tag){var tagName = tag || 'DIV'return document.createElement(tagName)},appendEle:function(ele,father){var father = father || document.body || document.documentElementfather.appendChild(ele)return ele;},addStyle:function(ele,css){for(var i in css){switch(i){case 'b' : ele.style.background = css[i]; break;case 'l' : ele.style.left = css[i]+'px'; break;case 'r' : ele.style.right = css[i]+'px'; break;case 't' : ele.style.top = css[i]+'px'; break;case 'd' : ele.style.down = css[i]+'px'; break;case 'p' : ele.style.position = css[i]; break;case 'w' : ele.style.width = css[i]+'px'; break;case 'h' : ele.style.height = css[i]+'px'; break;case 'f' : ele.style.cssFloat = css[i]; ele.style.styleFloat = css[i]; break;default : ele.style[i] = css[i]; break;}}return ele;},pushEleInSelect:function(){for(var i = 0; i<arguments.length; i++){Star.data.arraySelect = [arguments[i]].concat(Star.data.arraySelect)this.addStyle(arguments[i],{b:'#f00'})}}}Star.data={arrayAll : [],arraySelect:[],newPoint:null,foodNumber:0}Star.timeInterval={timeA:null,timeB:null}Star.keycode = 0;window.onload = function(){var select = Star.creatEle('select');var optionDefault = Star.creatEle('option');optionDefault.innerHTML = '請選擇關卡'Star.appendEle(optionDefault,select)Star.addStyle(select,{w:200,h:30,p:'absolute',left:'40%',top:'40%'})for(var i = 0 ; i <10 ; i++){var option = Star.creatEle('option');option.innerHTML = '第' + (i+1) + '關'Star.appendEle(option,select);}Star.appendEle(select)select.onchange = function(){selectValue = select.options[select.selectedIndex].value || select.options[select.selectedIndex].innerHTMLvar number = selectValue.match(//d+/)[0]Star.timeInterval.speed = parseInt(200/number);Star.addStyle(select,{display:'none'});Star.init();}}</script></html>

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久在线观看| 国产精品激情av电影在线观看| 欧美激情国产日韩精品一区18| 欧美电影在线观看完整版| 久久久影视精品| 精品av在线播放| 久久国产精品影视| 亚洲国产又黄又爽女人高潮的| 国产一区二区三区视频免费| 亚洲缚视频在线观看| 精品久久久999| 亚洲欧美激情四射在线日| 亚洲精品丝袜日韩| 欧美激情视频一区二区三区不卡| 欧美成人在线免费| 日韩精品在线看| 久久精品欧美视频| 日韩成人小视频| 九九热精品视频在线播放| 中文字幕日本精品| 午夜精品一区二区三区在线视频| 情事1991在线| 国产中文日韩欧美| 91精品久久久久久久久| 136fldh精品导航福利| 91精品国产九九九久久久亚洲| 成人国产精品日本在线| 91夜夜揉人人捏人人添红杏| 国产一区二区黑人欧美xxxx| 欧美网站在线观看| 欧美综合第一页| 97视频在线观看成人| 欧美激情第6页| 亚洲国产精品高清久久久| 欧美一级淫片aaaaaaa视频| 亚洲乱亚洲乱妇无码| 久久99热精品这里久久精品| 国内精品小视频| 日本一本a高清免费不卡| 欧美一区二区三区四区在线| 亚洲国产精品高清久久久| 国产剧情日韩欧美| 中文字幕亚洲一区| 国产不卡一区二区在线播放| 欧美有码在线视频| 欧美在线观看日本一区| 国内精品久久久久| 亚洲伦理中文字幕| 日韩精品视频在线观看免费| 久国内精品在线| 97久久精品人人澡人人爽缅北| 91国语精品自产拍在线观看性色| 国产欧美一区二区三区四区| 欧美色视频日本高清在线观看| 久久久久久久久久久久久久久久久久av| 国产精品爽爽爽| 精品久久久香蕉免费精品视频| 91av在线视频观看| 午夜精品一区二区三区av| 国产精品大片wwwwww| 欧美成人激情在线| 91精品国产亚洲| 97高清免费视频| 欧美一级在线播放| 亚洲国产欧美一区二区三区同亚洲| 欧洲精品久久久| 97久久精品人人澡人人爽缅北| 富二代精品短视频| 国产欧美一区二区三区四区| 日韩av123| 欧美性猛交xxxx免费看久久久| 成人乱色短篇合集| 久久av资源网站| 久久久久亚洲精品成人网小说| 亚洲free性xxxx护士白浆| 国产精品欧美一区二区| 亚洲一区二区久久久| 久久伊人91精品综合网站| 日韩免费在线观看视频| 国产精品草莓在线免费观看| 欧美成人三级视频网站| 国产精品成人品| 69影院欧美专区视频| 欧美黑人极品猛少妇色xxxxx| 91av在线看| 亚洲人a成www在线影院| 韩国国内大量揄拍精品视频| 欧美日在线观看| 日本精品va在线观看| 亚洲国内高清视频| www.久久久久久.com| 91精品国产亚洲| 91精品啪aⅴ在线观看国产| 久久久av网站| 法国裸体一区二区| 久久这里有精品视频| 久久精视频免费在线久久完整在线看| 亚洲欧美精品一区| 久久精品国产96久久久香蕉| 一本色道久久综合亚洲精品小说| 成人乱人伦精品视频在线观看| 久久精品国产欧美亚洲人人爽| 亚洲欧洲第一视频| 日韩视频免费大全中文字幕| 国产精品观看在线亚洲人成网| 国产亚洲精品美女久久久久| 国内精品在线一区| 黑人巨大精品欧美一区二区一视频| 欧美极品在线视频| 亚洲欧美色图片| 日韩高清av在线| 欧美亚洲视频一区二区| 日韩av日韩在线观看| 理论片在线不卡免费观看| 国产亚洲精品久久久久久| 国产精品成人观看视频国产奇米| 久久精品色欧美aⅴ一区二区| 国产精品久久久久久婷婷天堂| 亚洲女人天堂成人av在线| 性欧美长视频免费观看不卡| 国产精品高潮呻吟久久av无限| 国产精品自产拍在线观看| 久久精品视频导航| 中文字幕国产亚洲2019| 国产精品444| 久久久久久久久久av| 日韩禁在线播放| 欧美国产亚洲精品久久久8v| 亚洲第一福利在线观看| 欧美日韩电影在线观看| 亚洲色图18p| 疯狂做受xxxx欧美肥白少妇| 亚洲男人的天堂网站| 清纯唯美亚洲综合| 亚洲最大福利视频| 在线观看视频99| 国产精品最新在线观看| 5252色成人免费视频| 一区二区日韩精品| 国产婷婷色综合av蜜臀av| 精品国产91久久久久久| 91精品在线国产| 亚洲另类欧美自拍| 欧美在线中文字幕| 国产一区二区在线播放| 亚洲曰本av电影| 国产精品亚洲美女av网站| 欧美一区二区.| 青青草一区二区| 久久免费视频网站| 久久久国产精品亚洲一区| 国产美女精品视频| 国产色综合天天综合网| 亚洲free嫩bbb| 91亚洲精品在线| 亚洲精品网站在线播放gif| 美日韩在线视频| 日韩一二三在线视频播| 亚洲成人久久一区| 夜夜嗨av一区二区三区免费区| 久久久久久高潮国产精品视| 欧美日韩一区二区在线播放| 精品国内自产拍在线观看| 日韩经典中文字幕|