JavaScript 打地鼠游戏代码说明


Posted in Javascript onOctober 12, 2010

演示地址:http://demo.3water.com/js/mouse/index.html
打包下载地址 https://3water.com/jiaoben/32434.html
这个是我无聊的时候写的,先看看效果(UI做得比较丑):
JavaScript 打地鼠游戏代码说明 
说明:红色的点击得分100,蓝色的点击扣分100.

只是想用js来写个小游戏,顺便练练js的代码。
先看html部分:
html

<style> 
#panel{height:300px;width:300px;background:#ccc;margin:50px 0 0 200px;} 
#panel ul{list-style:none;display:block;float:left;margin:0;padding:0;} 
#panel li{display:block;float:left;width:100px;height:100px; 
overflow:hidden;position:relative;text-align:center;} 
#panel li span{display:block;position:relative;left:0;top:60px; 
width:100px;height:40px;background:url(img/hole.gif) 0 -60px;z-index:100;} 
</style> 
</head> 
<body> 
<span>说明:红色的点击得分100,蓝色的点击扣分100.</span> 
<div id="panel"> 
<ul> 
<li><span></span></li> 
<li><span></span></li> 
<li><span></span></li> 
<li><span></span></li> 
<li><span></span></li> 
<li><span></span></li> 
<li><span></span></li> 
<li><span></span></li> 
<li><span></span></li> 
</ul> 
</div> 
<div>分数:<span id="score">0</span></div> 
<div>倒计时:<span id="time">60</span></div> 
<input type="button" value="开始" onclick="GameStart()" />

js部分:地鼠类
var Mouse = function(type){ 
//地鼠的具体dom元素,添加到页面上的 
this.mouse = null; 
//地鼠的编号 
this.num = -1; 
//地洞的编号(地鼠藏身在哪个洞) 
this.hole = -1; 
//初始化,type为地鼠类型,好与坏 
this.init(type); 
} 
Mouse.prototype = { 
//地鼠类型,好,坏,好的被杀,坏的被杀 
mousetype: { 
"good": "img/good.gif", 
"bad": "img/bad.gif", 
"goodkill":"img/goodkill.gif", 
"badkill":"img/badkill.gif" 
}, 
//初始化地鼠 
init : function(type){ 
type = type || 'good'; 
var _this = this; 
//创建地鼠的dom元素 
this.mouse = document.createElement("div"); 
//扩展属性--地鼠类型 
this.mouse.mousetype = type; 
//扩展类型--属否活着 
this.mouse.islive = true; 
this.mouse.style.cssText = 'width:75px;height:100px;background:url('+this.mousetype[type]+');left:0;top:20px;\ 
position:relative;margin:auto;cursor:pointer;'; 
//绑定地鼠被点击事件 
this.mouse.onclick = function(e){_this.beat(e);}; 
}, 
//地鼠被点中 
beat : function(e){ 
if(this.mouse.islive){ 
this.mouse.islive = false; 
this.onbeat(); 
this.mouse.style.background = "url("+this.mousetype[this.mouse.mousetype+"kill"]+")"; 
} 
}, 
//地鼠的动画 
animation : function(speed){ 
speed = speed == 'fast'?20:speed == 'normal'?30:50; 
var obj = this.mouse,ost = obj.style,oTop = parseInt(ost.top,10),cut=5,_this = this; 
//让地鼠从地洞冒出来 
var show = function(top){ 
top = top-cut; 
if(top >= -40){ 
ost.top = top + 'px'; 
setTimeout(function(){show(top);},speed); 
} 
else 
{ 
setTimeout(function(){hide(-40);},speed*10); 
} 
} 
//隐藏地鼠 
var hide = function(top){ 
top = top+cut; 
if(top <= oTop){ 
ost.top = top + 'px'; 
setTimeout(function(){hide(top);},speed); 
} 
else { 
_this.reset(); 
} 
} 
show(oTop); 
}, 
//重置地鼠,当地鼠滚回洞里的时候 
reset : function(){ 
this.mouse.islive =true; 
this.mouse.style.background = "url("+this.mousetype[this.mouse.mousetype]+")"; 
this.onend(); 
}, 
//扩展方法:地鼠被点中 
onbeat : function(){}, 
//扩展方法:地鼠动画结束后 
onend : function(){} 
}

接着是游戏控制类,控制游戏的逻辑:
//游戏控制类 
var Game = { 
//游戏时间,一分钟 
time : 61, 
//地鼠地图,总共有十只,其中两只是坏的 
mouseMap : { 
1:'good', 
2:'bad', 
3:'good', 
4:'good', 
5:'bad', 
6:'good', 
7:'bad', 
8:'good', 
9:'good', 
10:'good' 
}, 
//所有的地鼠dom元素 
allMouse : [], 
//目前分数 
nowScore : 0, 
//目前有哪几个地洞给占用 
hasHole : {}, 
//目前有哪几只地鼠是活动的 
hasMouse : {}, 
//页面的地洞集合 
lis : null, 
//初始化地鼠与地洞 
init : function(){ 
//获取页面的地洞集合 
this.lis = document.getElementById('panel').getElementsByTagName('li'); 
_this = this; 
//初始化10只地鼠 
for(var i=1;i <=10;i++){ 
var mouse = new Mouse(this.mouseMap[i]); 
//扩展地鼠被点中事件 
mouse.onbeat = function(){ 
//修改分数 
Game.changeScore(100 * (this.mouse.mousetype=='good'?1:-1)); 
} 
//扩展地鼠动画结束事件 
mouse.onend = function(){ 
//移除地洞中的地鼠 
var li = _this.lis[this.hole]; 
li.removeChild(li.mouse.mouse); 
li.mouse = null; 
//清除对应的地洞与地鼠 
_this.hasHole[this.hole] = null; 
_this.hasMouse[this.num] = null; 
} 
this.allMouse.push(mouse); 
} 
}, 
//修改游戏分数 
changeScore : function(score){ 
this.nowScore += score; 
document.getElementById('score').innerHTML = this.nowScore; 
}, 
//游戏开始 
start : function(){ 
if(this.time <= 0)return; 
var _this = this; 
//随机地洞编号 
var random = parseInt(Math.random()*9,10); 
while(this.hasHole[random]){ 
random = parseInt(Math.random()*9,10); 
} 
//随机地鼠编号 
var randomMouse = parseInt(Math.random()*10,10); 
while(this.hasMouse[randomMouse]){ 
randomMouse = parseInt(Math.random()*10,10); 
} 
//添加地鼠到地洞中 
this.allMouse[randomMouse].hole = random; 
this.allMouse[randomMouse].num = randomMouse; 
this.lis[random].appendChild(this.allMouse[randomMouse].mouse); 
this.lis[random].mouse = this.allMouse[randomMouse]; 
this.lis[random].mouse.animation('normal'); 
//记录地鼠与地洞编号 
this.hasHole[random] = 'true'; 
this.hasMouse[randomMouse] = 'true'; 
setTimeout(function(){_this.start();},250); 
}, 
//倒计时 
startTime : function(){ 
this.time -= 1; 
var _this = this; 
document.getElementById('time').innerHTML = this.time; 
if(this.time > 0){ 
setTimeout(function(){_this.startTime()},1000); 
} 
}, 
//重置游戏设置 
reset : function(){ 
this.time = 61; 
this.allMouse = []; 
this.nowScore = 0; 
this.hasHole = {}; 
this.hasMouse = {}; 
this.lis = null; 
this.changeScore(0); 
} 
} 
//游戏开始函数 
function GameStart(){ 
if(Game.time > 0 && Game.time != 61){ 
alert("游戏尚未结束,不能重新开始哦!"); 
return; 
} 
Game.reset(); 
Game.init(); 
Game.start(); 
Game.startTime(); 
}

这样就完成了。。。功能还是很简陋。。。只是想说明,js还是可以做小游戏的。。。欢迎拍砖!
Javascript 相关文章推荐
jQuery 常见学习网站与参考书
Nov 09 Javascript
javascript的内存管理详解
Aug 07 Javascript
js 遍历json返回的map内容示例代码
Oct 29 Javascript
javascript复制粘贴与clipboardData的使用
Oct 16 Javascript
JavaScript生成随机字符串的方法
Mar 19 Javascript
JavaScript 对象深入学习总结(经典)
Sep 29 Javascript
JS小数转换为整数的方法分析
Jan 07 Javascript
JS传播事件、取消事件默认行为、阻止事件传播详解
Aug 14 Javascript
AngularJs 终极购物车(实例讲解)
Nov 08 Javascript
代码详解javascript模块加载器
Mar 04 Javascript
vue项目如何刷新当前页面的方法
May 18 Javascript
Vue指令v-for遍历输出JavaScript数组及json对象的常见方式小结
Feb 11 Javascript
理解Javascript_03_javascript全局观
Oct 11 #Javascript
理解Javascript_02_理解undefined和null
Oct 11 #Javascript
理解Javascript_01_理解内存分配原理分析
Oct 11 #Javascript
javascript getElementsByClassName实现代码
Oct 11 #Javascript
javascript Array.prototype.slice使用说明
Oct 11 #Javascript
javascript 伪数组实现方法
Oct 11 #Javascript
javascript forEach通用循环遍历方法
Oct 11 #Javascript
You might like
PHP函数篇详解十进制、二进制、八进制和十六进制转换函数说明
2011/12/05 PHP
php 检查电子邮件函数(自写)
2014/01/16 PHP
PHP APC缓存配置、使用详解
2014/03/06 PHP
PHP curl实现抓取302跳转后页面的示例
2014/07/04 PHP
使用ucenter实现多站点同步登录的讲解
2019/03/21 PHP
laravel框架分组控制器和分组路由实现方法示例
2020/01/25 PHP
写给想学习Javascript的朋友一点学习经验小结
2010/11/23 Javascript
jquery内置验证(validate)使用方法示例(表单验证)
2013/12/04 Javascript
提交按钮的name='submit'引起的js失效问题及原因
2015/02/25 Javascript
JavaScript实现的Tween算法及缓冲特效实例代码
2015/11/03 Javascript
Spring mvc 接收json对象
2015/12/10 Javascript
Bootstrap按钮下拉菜单组件详解
2016/05/10 Javascript
详解闭包解决jQuery中AJAX的外部变量问题
2017/02/22 Javascript
AngularJS发送异步Get/Post请求方法
2018/08/13 Javascript
Vue.js图片预览插件使用详解
2018/08/27 Javascript
vue使用swiper.js重叠轮播组建样式
2019/11/14 Javascript
JavaScript图片旋转效果实现方法详解
2020/06/28 Javascript
在Python的Flask框架中实现单元测试的教程
2015/04/20 Python
用Python写冒泡排序代码
2016/04/12 Python
详解Python 模拟实现生产者消费者模式的实例
2017/08/10 Python
浅谈Python实现2种文件复制的方法
2018/01/19 Python
Python安装pycurl失败的解决方法
2018/10/15 Python
解决Mac下首次安装pycharm无project interpreter的问题
2018/10/29 Python
基于PyQt4和PySide实现输入对话框效果
2019/02/27 Python
Python字典的概念及常见应用实例详解
2019/10/30 Python
python将邻接矩阵输出成图的实现
2019/11/21 Python
解决pymysql cursor.fetchall() 获取不到数据的问题
2020/05/15 Python
学python爬虫能做什么
2020/07/29 Python
python多线程和多进程关系详解
2020/12/14 Python
法国家具及室内配件店:home24
2017/01/21 全球购物
ETO男装官方网店:ETO Jeans
2019/02/28 全球购物
乌克兰品牌化妆品和香水在线商店:Bomond
2020/01/14 全球购物
《落花生》教学反思
2014/02/25 职场文书
同居协议书范本
2014/04/23 职场文书
酒店员工管理制度
2015/08/05 职场文书
Python中np.random.randint()参数详解及用法实例
2022/09/23 Python