国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

js貪吃蛇網頁版游戲特效代碼分享(挑戰十關)

2019-11-20 11:44:49
字體:
來源:轉載
供稿:網友

js貪吃蛇網頁版游戲特效,經測試圖片切換過程非常酷,相信大家一定都玩過這個經典小游戲吧,但是它是怎么實現的吶,感興趣的朋友快來學習學習吧
運行效果圖:----------------------查看效果-----------------------

小提示:瀏覽器中如果不能正常運行,可以嘗試切換瀏覽模式。
為大家分享的js貪吃蛇網頁版游戲特效代碼如下

<body><title>js貪吃蛇網頁版游戲特效</title></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.documentElement  father.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].innerHTML  var number = selectValue.match(//d+/)[0]  Star.timeInterval.speed = parseInt(200/number);  Star.addStyle(select,{display:'none'});  Star.init(); } }</script>


以上就是為大家分享的js貪吃蛇網頁版游戲特效代碼,希望大家可以喜歡。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 塔城市| 富蕴县| 军事| 永德县| 体育| 乡城县| 汝城县| 肇庆市| 鄂托克旗| 永顺县| 淳化县| 大方县| 山阳县| 吐鲁番市| 民权县| 通州区| 普安县| 朝阳市| 桦南县| 本溪| 呼图壁县| 平泉县| 子长县| 定安县| 昌平区| 安达市| 青冈县| 钟山县| 海原县| 二手房| 迁西县| 兴国县| 高安市| 浏阳市| 正阳县| 原平市| 唐河县| 临漳县| 卢湾区| 沙洋县| 福贡县|