setTimeout 如何调用本身

MoviePlayer.prototype.moveDiv = function() {
 var curDiv = $('u' + this.groupName + '_' + this.current_id);
 if(curDiv.style.posLeft != 0) {
  curDiv.style.posLeft = curDiv.style.posLeft * 0.8;
  var self = this;
   window.setTimeout(function(){ self.moveDiv(); }, 30);
 } else {
  
 }
}

 

 

上述调用的时候,要注意两个地方:

 

  • 注意this引用的存储,如果在setTimeout里写this,那么系统会认为this指向setTimeout方法所属的window对象;
  • setTimeout里的参数的正确写法:window.setTimeout(function(){ self.moveDiv(); }, 30);而不是window.setTimeout(self.moveDiv, 30);

非常感谢js 中 setTimeout()的用法, 该文分析得比较详细。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值