在JavaScript中,prototype对象是实现面向对象的一个重要机制。

每个函数就是一个对象(Function),函数对象都有一个子对象 prototype对象,类是以函数的形式来定义的。prototype表示该函数的原型,也表示一个类的成员的集合。

在游戏中,首先我们先想想地鼠拥有哪些属性:

(1)地鼠的编号

(2)地鼠图片所在的dom元素

(3)地鼠所在地洞的编号

(4)地鼠的类型(有效,无效)

定义一个名称为Mouse的函数(方法)初始化地鼠属性

var Mouse=function(type){
this.mouse=null;//地鼠所在的巢穴()dom元素
this.num=-1;//地鼠编号
this.hole=-1;//地鼠所在地洞编号
this.init(type);//初始化地鼠,有效地鼠,无效地鼠
}

为了方便和统一,有效的对地鼠拥有的属性进行操作和扩展,我们使用 prototype 属性来向函数(对象)Mouse扩展和添加属性:

Mouse.prototype={

	//地鼠类型,有效,无效,有效的被杀,无效的被杀

	mousetype: {
"num1": "0 0;height:100px;width:111px;",
"num2": "-14px -114px;height:100px;width:97px;",
"num3": "-8px -225px;height:100px;width:98px;",
"num4": "-14px -335px;height:100px;width:92px;",
"num5": "-8px -455px;height:100px;width:115px;",
"dot": "background:url(img/dot.png) no-repeat;width:115px;height:100px;",
"dotNo": "background:url(img/dotNo.png) no-repeat;width:115px;height:100px;",
},
}

在上面Mouse的函数中,我们可以看到地鼠的属性中,我们需要对地鼠所在的(巢穴)进行初始化和属性扩展:

(1)创建地鼠所在的(巢穴)dom元素

(2)巢穴中的地鼠的类型(有效,无效) 

(3)巢穴中的地鼠的状态(死,活)

(4)巢穴中地鼠的位置(出现,隐藏) 

(5)巢穴被袭击事件(单击事件)

综上我们可以得到这么一个init()函数

//初始化地鼠
//初始化地鼠
init : function(type){
type = type || 'num1';
var _this = this;
//创建地鼠的dom元素
this.mouse = document.createElement("div");
//扩展属性--地鼠类型
this.mouse.mousetype = type;
//扩展类型--属否活着
this.mouse.islive = true;
this.mouse.style.cssText = 'background:url(img/mouse.png) no-repeat;left:0;top:0px;\
position:relative;margin:auto;cursor:pointer;background-position:'+this.mousetype[type]+'';
//绑定地鼠被点击事件
this.mouse.onclick = function(e){_this.beat(e);};
},

  

在上面我们已经绑定了地鼠巢穴的单击事件,下面我们需要写单击事件的方法:

在单击时,我们需要判断巢穴中地鼠的状态,是死,是活,如果是死的那么单击无效。

//地鼠被点击
//地鼠被点击
beat:function(e){
if(this.mouse.islive==true){
this.mouse.islive=false;//杀死
this.onbeat();//地鼠被点中扩展方法
if(this.mouse.mousetype=='num2'||this.mouse.mousetype=='num3'){
this.mouse.style = this.mousetype['dotNo'];//显示被杀的场面
}
else{
this.mouse.style = this.mousetype['dot'];//显示被杀的场面
}
console.log(this.mouse.getAttribute("style")); }
},
//地鼠被点中扩展方法
onbeat:function(){},

地鼠被杀死后的扩展方法,我们可以去想衍生出很多有趣场面和特效,后面的游戏过程也会使用到,这里不扩展讲解

同时我们还知道我们的地鼠还具有动画属性,下面说说动画效果:

我们使用元素的绝对定位的top值来实现动画的隐藏和显示。

	//地鼠的动画
animation : function(speed){ speed = speed == 'fast'?20:speed == 'normal'?30:50; var obj = this.mouse,ost = obj.style,oTop = 0,cut=5,_this = this;
//让地鼠从地洞冒出来
var show = function(top){ top = top-cut; if(top >= -40&&top<oTop){
obj.style = 'background:url(img/mouse.png) no-repeat;left:0;top:0px;\
position:relative;margin:auto;cursor:pointer;background-position:'+_this.mousetype[obj.mousetype]+'';
ost.top = top + 'px';
setTimeout(function(){show(top);},speed);
}
else
{
setTimeout(function(){hide(-40);},speed*10);
}
},
//扩展方法:地鼠动画结束后
onend : function(){},

上面最好有一个onend动画结束的扩展方法,后面的游戏的过程中会用到,我们也可以在这个方法自定义

在游戏中我们需要一个重置让所有的地鼠回滚到洞穴里

//重置地鼠,当地鼠滚回洞里的时候
//重置地鼠,当地鼠滚回洞里的时候
reset : function(){
this.mouse.islive =true;
this.mouse.style= 'background:url(img/mouse.png) no-repeat;left:0;top:0px;\
position:relative;margin:auto;cursor:pointer;background-position:'+this.mousetype[this.mouse.mousetype]+'';
this.onend();
},

  

打地鼠游戏(2)之定义地鼠函数及函数原型 prototype的更多相关文章

  1. 团队项目——打地鼠游戏(SPEC)系统性能评估测试

    1.SPEC测试的目标: 本轮测试的目的是测试打地鼠游戏的需求以及确保每个需求都能得到满足的方法.编写此需求说明书是为了使用户和开发人员对所开发的系统有一致的理解.通过阅读此说明书,开发人员可以了解当 ...

  2. 无聊的人用JS实现了一个简单的打地鼠游戏

    直入正题,用JS实现一个简单的打地鼠游戏 因为功能比较简单就直接裸奔JS了,先看看效果图,或者 在线玩玩 吧 如果点击颜色比较深的那个(俗称坏老鼠),将扣分50:如果点击颜色比较浅的那个(俗称好老鼠) ...

  3. 410 for 循环 运算 改变循环的控制流 死循环 遍历数组 定义方法 有名函数匿名函数 定义函数的方法取值 date math 局部变量 函数 局部与全局变量 次幂/随机数/取绝对值/向上取整/平方根

    for(1.表达式1;2.表达式2;3.表达式3){ 4.循环体语句; } 先执行1 ,在执行2, 表达式, 如果2结果为false,退出循环 如果2是true 执行4 在执行3 执行2 举例打印1- ...

  4. Angular4 自制打地鼠游戏

    前端工程师新手一枚,之前一直做些小设计,以及静态页面的编写工作.刚刚接触 Angular 没有多久,四个月前对于 Javascript也只是会写 alert 之流,现在进步算是很大,下面是自制的打地鼠 ...

  5. Android 多线程 打地鼠游戏

    前言:最近比较喜欢多线程了,看到了一些线程案例,这里总结一下打地鼠游戏的整个过程. 1.首先是主活动要加载的布局,我一般就喜欢早点把这个写上,这样就好在主活动中玩弄这些控件了.闲话不多说,一个Fram ...

  6. iOS版打地鼠游戏源码

    打地鼠游戏源码,游戏是一款多关卡基于cocos2d的iPad打地鼠游戏源码,这也是一款高质量的打地鼠游戏源码,可以拥有逐步上升的关卡的设置,大家可以在关卡时设置一些商业化的模式来盈利的,非常完美的一款 ...

  7. 打地鼠游戏iOS源码项目

    打地鼠游戏源码,游戏是一款多关卡基于cocos2d的iPad打地鼠游戏源码,这也是一款高质量的打地鼠游戏源码,可以拥有逐步上升的关卡的设置,大家可以在关卡时设置一些商业化的模式来盈利的,非常完美的一款 ...

  8. 将对象的所有属性名放到一个数组中 || 获得对象的所有属性名 || return;不具有原子性 || 怎样自己制作异常|| 判断对象有没有某个属性 || 当传递的参数比需要的参数少的时候,没有的值会被赋予undefined || 获得函数实际传递的参数 || 怎么用函数处理一个对象 || 用一个名字空间定义一个模块所有的函数 || 给一个对象添加方法

    获得对象的所有属性名 || 将对象o的所有属性名放到数组中 var o = {x:1,y:2,z:3}; var arr = []; var i = 0; for(arr[i++] in o){};/ ...

  9. 打地鼠游戏ios源码

    打地鼠游戏源码,游戏是一款多关卡基于cocos2d的iPad打地鼠游戏源码,这也是一款高质量的打地鼠游戏源码,可以拥有逐步上升的关卡的设置,大家可以在关卡时设置一些商业化的模式来盈利的,非常完美的一款 ...

  10. Android打地鼠游戏源码带道具购买的Android游戏开发

    这是一款基于安卓的打地鼠游戏,界面简洁,有level模式打地鼠和无尽模式打地鼠两种游戏模式,并可以通过商店使用金币进行道具的购买,道具可以让你更容易通关:同时金币可以在游戏通关的时候获取.工程中有较为 ...

随机推荐

  1. JavaScript--结合CSS变形、缩放能拖拽的登录框

    上例图: 代码块: <!DOCTYPE html> <html> <head lang="en"> <meta charset=" ...

  2. 苹果建议开发者在iOS 7正式发布之前把应用提交至App Store

    今早在给开发者的邮件中,苹果建议开发者在下周9月18日正式发布iOS 7之前把应用提交至App Store.邮件特别提到了iOS 7的新功能,还提到了充分利用iPhone 5S功能的新API,比如M7 ...

  3. vuxdemo1

    //main.js import Vue from 'vue' import router from './router' import store from './store' import axi ...

  4. php中括号定义数组

    php5.3及之前的版本是不支持中括号定义数组的.5.4之后支持. 错误信息是,不识别“[”

  5. mysql中bigint、int、mediumint、smallint与tinyint的取值范围

    https://blog.csdn.net/github_39110707/article/details/74277381 mysql数据库设计,其中对性能优化,字段类型很重要,下面对bigint. ...

  6. IDEA-servlet项目创建web项目

    准备:1. 安装jdk1.82. 安装tomcat9.0(idea只支持4.0  9.0的服务器) 一.创建并设置javaweb工程 1.创建javaweb工程File --> New --&g ...

  7. UVA_694:The Collatz Sequence

    Language: C++ 4.8.2 #include<stdio.h> int main(void) { long long int m, n, copy_m; ; ; ) { sca ...

  8. Libevent:6辅助函数以及类型

    在头文件<event2/util.h>中定义了许多有用的函数和类型来帮助实现可移植的程序.Libevent在内部使用这些类型和函数. 一:基本类型 evutil_socket_t 除了Wi ...

  9. AtCoder Beginner Contest 075 C bridge【图论求桥】

    AtCoder Beginner Contest 075 C bridge 桥就是指图中这样的边,删除它以后整个图不连通.本题就是求桥个数的裸题. dfn[u]指在dfs中搜索到u节点的次序值,low ...

  10. 云原生生态周报 Vol. 2

    摘要: Cloud Native Weekly China Vol. 2 业界要闻 Kubernetes External Secrets 近日,世界上最大的域名托管公司 Godaddy公司,正式宣布 ...