我有以下代码:
$('.p1').click(function(){
var num = 10;
var count = 0;
var intv = setInterval(anim,800);
function anim(){
count++;
num--;
if(num==0){clearInterval(intv);}
$(this).hide(function(){
$(this).appendTo('#box_'+count);
}).delay(500).fadeIn();
}
anim();
});
我不知道,如果动画输入功能出现错误,请帮帮我
答案 0 :(得分:2)
anim()
函数没有this
上下文。 click事件确实拥有它,但不会自动传递给您的其他函数。您可以使用.bind()
和.call()
:
var intv = setInterval(anim.bind(this),800);
...
...
anim.call(this);
.bind()
用于setInterval
行,因为您希望在设置this
上下文时调用该函数(不调用它)。 .call()
用于最后一行,因为您要调用该函数并设置this
上下文。
或者,您可以将this
上下文存储为另一个变量,使其可以在anim()
函数中访问:
// in the click event
var element = this;
function anim(){
count++;
num--;
if(num==0){clearInterval(intv);}
$(element).hide(function(){
$(element).appendTo('#box_'+count);
}).delay(500).fadeIn();
}