|
這個(gè)問題可麻煩了,我經(jīng)常要在循環(huán)函數(shù)里用this來引用當(dāng)前對(duì)象,也許你想到可以用閉包,不過實(shí)際情況并非如此簡單,對(duì)象實(shí)例多了之后,閉包也亂套了.
我的愿望就是讓循環(huán)函數(shù)里的this仍然指向當(dāng)前上下文的對(duì)象,無需傳參數(shù),無需閉包(其實(shí)這也是閉包,只是形式上看著比較自然而已);
例如:(一部分代碼,作用是定時(shí)發(fā)送請(qǐng)求)
復(fù)制代碼 代碼如下:
var sendRequest=function(){}
sendRequest.prototype={
.............................
.............................
beginSend:function(){
//使循環(huán)函數(shù)里的this指向本對(duì)象,而不是全局對(duì)象
this.loop_send=setInterval((function(param){
return function(){param.sendARequest();}
})(this),this.options.interval);
},
sendARequest:function(){
this.num++;
this.checkLimit();
var callback = {
success: this.handleSuccess,
failure: this.handleFail,
argument: {
handle: this,
timeout:500
}
}
var post_data="...."
//如果待發(fā)送的數(shù)據(jù)不為空,則將取出一條數(shù)據(jù)發(fā)到后臺(tái)
if(this.data_wait_for_send.length!=0){
for(var i=0,j=this.data_wait_for_send.length;i<j;i++){
post_data+="&content[]="+this.data_wait_for_send[i];
}
this.data_wait_for_send=[]
}
// debug(post_data)
var que = Connect.asyncRequest('POST', this.options.getUrl, callback,post_data);
},
......................
......................
}
如此,在sendARequest()函數(shù)里,我們可以正常使用this來引用當(dāng)前對(duì)象,使用當(dāng)前對(duì)象的變量和方法,這樣豈不是很方便?
JavaScript技術(shù):javascript讓setInteval里的函數(shù)參數(shù)中的this指向特定的對(duì)象,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。