首页 > 代码库 > Snake小游戏
Snake小游戏
var title=document.querySelector(".title");
var wrap=document.querySelector(".wrap")
warp.style.left=(document.documentElement.clientWidth-wrap.offsetWidth)/2+"px";
drag(title,wrap); //设置游戏框的拖拽
/*
HTML DOM querySelector()方法:
querySelector()方法返回文档中匹配指定 CSS 选择器的一个元素;
实例:
获取文档中id="demo"的第一个元素
document.querySelector("#demo");
注意:querySelector()方法仅返回匹配指定选择器的第一个元素。如需返回全部元素,使用 querySelectorAll() 方法;
jQuery wrap()方法
wrap()方法使用指定的 HTML 元素来包裹每个被选元素。
实例:
在<div>元素中包裹P元素
$("button").click(function(){
$("p").wrap("<div></div>")
});
scrollWidth
是对象的实际内容的宽,不包边线宽度,会随对象中内容的多少改变(内容多了可能会改变对象的实际宽度)。
clientWidth
是对象可见的宽度,不包滚动条等边线,会随窗口的显示大小改变。
offsetWidth
是对象的可见宽度,包滚动条等边线,会随窗口的显示大小改变。
*/
var ohScore=document.querySelector(".hScore");
var oScore=document.querySelector(".score");
var score=0; //初始分0
//设置最高分为之前存储过的最高分
if(localStorage.getItem(‘max‘)){
ohScore.innerHTML="历史最高分 :"+localStorage.getItem(‘max‘)+" 分";
}
var ulBox=document.queryScore(".boxWrap");
var c=28; //28列
var r=35; //35行
var allArr=[]; //用于装入所有的盒子
//创建游戏区域
for(var i=0;i<r;i++){
var rArr=[]; //装入的是一排所有的盒子
var rLi=document.createElement("li");
rLi.className="clearfix"; //清浮动
for(var j=0;j<c;j++){
var box=document.createElement("div");
rArr.push(box);
rLi.appendChild(box)
}
ulBox.appendChild(rLi);
allArr.push(rArr);
}
//蛇的移动
var stepTime; //蛇每走一步的时间
var moveTimer=null; //定时器
var direction=‘right‘;
var x=4,y=0 //起始位置
function move(){
moveTimer=setInterval(function(){
switch (direction){
case ‘right‘:
x++;
break;
case ‘left‘:
x--;
break;
case ‘up‘:
y--;
break;
case ‘down‘:
y++;
break;
}
if(x<0 || y<0 || x>=c || y>=r){
clearInterval(moveTimer);
gameOver() //游戏结束
return;
}
if(x==eggX && y==eggY && allArr[eggY][eggX].className==‘egg‘){ //防止createEgg()函数在递归时产生的eggX和eggY的影响
snakeArr.push(allArr[eggY][eggX]);
allArr[eggY][eggX].className="snake";
score++;
oScore.innerHTML=‘得分 :‘+score+" 分";
createEgg();
}
else{
//判断蛇是否咬到自己
if(allArr[y][x].className="snake"){
clearInterval(moveTimer);
gameOver(); //游戏结束
}
snakeArr[0].className="";
snakeArr.shift();
allArr[y][x].className="snake";
snakeArr.push(allArr[y][x]);
}
}
,stepTime)
}
/*
setInterval()方法可按照指定的周期(以毫秒计)来调用函数或表达式。
setInterval()方法会不停地调用函数,直到clearInterval()被调用或窗口被关闭。由setInterval()返回的ID值可用做clearInterval()方法的参数。
css direction 属性:
direction属性规定文本的方向/书写的方向
该属性指定了块的基本书写方向,以及针对 Unicode 双向算法的嵌入和覆盖方向。不支持双向文本的用户代理可以忽略这个属性。
ltr 默认。文本方向从左到右
rtl 文本方向从右到左
*/
//添加键盘的对蛇的控制
var ks=true; //阻止按键冲突,即防止下一次的按键覆盖上一次按键的操作
document.onkeydown=function(event){
if(!ks){
return;
}
//化解方向冲突,阻止蛇的原地反向
if(event.keyCode==37 && direction ==‘right‘){
return;
}
if(event.keyCode==39 && direction ==‘left‘){
return;
}
if(event.keyCode==40 && direction==‘up‘){
return;
}
if(event.keyCode==38 && direction==‘down‘){
return;
}
//设置键盘方向键对蛇的控制
switch(event.keyCode){
case 37:
direction="left";
break;
case 38:
direction="up";
break;
case 39:
direction="right";
break;
case 40:
direction="down";
break;
}
ks=false;
setTimeout(
function(){
ks=true;
}
,stepTime)
console.log(stepTime);
}
/*
onkeydown事件会在用户按下一个键盘按键发生
语法:onkeydown="SomeJavaScriptCode"
参数:SomeJavaScriptCode 必需。规定该事件发生时执行的JavaScript;
浏览器差异:Internet Explorer 使用 event.keyCode 取回被按下的字符,而 Netscape/Firefox/Opera 使用 event.which。
*/
//生成随机位置的蛋
var eggX,eggY; //蛋的位置索引
function createEgg(){
eggX=parseInt(Math.random()*c);
eggY=parseInt(Math.random()*r);
if(allArr[eggY][eggX].className!=‘snake‘){
allArr[eggY][eggX].className=‘egg‘;
}
else{
createEgg();
}
}
createEgg();
//开始按钮的点击事件,以及初中高游戏等级的选择按钮
var btn=document.getElementById("btn");
var snakeArr=[]; //用于装入蛇身体所有的方块
var btnChoose=document.querySelectorAll(".choose");
for(var i=0;i<btnChoose.length;i++){
btnChoose[i].style.background=‘gray‘; //先将所有难度按钮变灰
//定义难度按钮的点击事件
btnChoose[i].onclick=function(){
for (var j=0;j<btnChoose.length;j++){
btnChoose[j].style.background=‘gray‘;
}
this.style.background=‘ ‘; //此难度被选中
}
}
btn.onclick=function(){
init(); //游戏初始化
//判断用户选择的游戏难度
if(btnChoose[0].style.background==‘ ‘){
stepTime=280; //初级难度
}
else if(btnChoose[1].style.background==‘ ‘){
stepTime=140; //中级难度
}
else if(btnChoose[2].style.background==‘ ‘){
stepTime=70; //高级难度
}
else{
alert(‘请选择游戏难度~(^_^)‘);
return;
}
//封面收起特效
btn.parentNode.style.transform=‘rotate(180deg) scale(0)‘;
move();
}
/*
停止游戏,并弹出成绩,并记录最高分
*/
var gameOverBox=document.querySelector(".gameOver");
function gameOver(){
gameOverBox.innerHTML=‘<font size-"8" color="red">Game Over</font><br/>‘+"你的得分 :"+score+‘<span id="again">再来一次</span>‘+‘<span id="quit">退出游戏</span>‘;
gameOverBox.style.transform="scale(1)"; //transform 属性向元素应用 2D 或 3D 转换。该属性允许我们对元素进行旋转、缩放、移动或倾斜。
//退出游戏按钮的点击事件
document.getElementById("quit").onclick=function(){
btn.parentNode.style.transform=‘rotate(0deg) scale(1)‘;
gameOverBox.style.transform="scale(0)";
}
//设置再来一次按钮的点击事件
document.getElementById("again").onclick=function(){
gameOverBox.style.transform="scale(0)";
init();
move();
}
//设置最高分为web存储
var h=localStorage.getItem(‘max‘);
if(h==null || h<score){
localStorage.setItem(‘max‘,score); //localStorage 方法存储的数据没有时间限制。第二天、第二周或下一年之后,数据依然可用。
h=score;
}
ohScore.innerHTML="历史最高分 : "+h+" 分";
}
/*游戏初始化,将蛇身数组初始化
*并将之前的蛋复原,重新产蛋
*还有方向等一些设置
*/
function init(){
for (var i=0;i<snakeArr.length;i++){
snakeArr[i].className=‘ ‘; //将之前蛇的类名全部清空
}
allArr[eggY][eggX].className=‘ ‘ ; //把蛋去掉
x=4;
y=0;
//创建蛇身,将蛇身上色(重新载入对象)
snakeArr=[];
for (var i=0;i<5;i++){
snakeArr.push(allArr[0][i]);
snakeArr[i].className=‘snake‘;
}
createEgg();
direction=‘right‘;
score=0;
oScore.innerHTML=‘得分 : 0 分‘;
}
Snake小游戏