我目前正在进行一个小项目,以学习Js和OOP。但是我有一个问题,让我解释一下不同的步骤:
1)我的构造函数:
function Ammo(ammoId,posX,posY){
this.id=ammoId;
this.x=posX;
this.y=posY;
$('body').append('<div class="ammo ammo'+this.id+'"></div>');
}
2) 原型:
Ammo.prototype.position = function(){
$('.ammo'+this.id).css({
'top': this.y+"px",
'left': this.x+"px"
});
}
Ammo.prototype.ammomove = function(){
this.y-=1;
this.position();
}
3) 调用:
ammo=[];
var a=1;
function createAmmo(){
var ammoX=main.x;
var ammoY=main.y;
ammo[a] = new Ammo(a, ammoX, ammoY);
ammo[a].position();
var animAmmo= setInterval("ammo["+a+"].ammomove()",5);
a++;
}
createAmmo();
我的程序运行得非常完美。但是当我使用以下语法声明数组时:
var ammo = [];
它不起作用,并显示错误"未定义弹药(ammo)", 而这个可以工作:
ammo = [];
有人有想法吗?谢谢!
编辑:这是我的JsFiddle:https://jsfiddle.net/seabon/c057f1oj/
按下空格键调用createAmmo()