一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

javascript讓setInteval里的函數參數中的this指向特定的對象

看到這個題,我蒙了,因為那時候我不清除這個問題,想了半天沒想出來,后來到網上一查,在國外的某網站查到說setInterval和setTimeout之后的函數的作用域是全局的,也就是里面的this指向的是全局對象.
這個問題可麻煩了,我經常要在循環函數里用this來引用當前對象,也許你想到可以用閉包,不過實際情況并非如此簡單,對象實例多了之后,閉包也亂套了.
我的愿望就是讓循環函數里的this仍然指向當前上下文的對象,無需傳參數,無需閉包(其實這也是閉包,只是形式上看著比較自然而已);
例如:(一部分代碼,作用是定時發送請求)
復制代碼 代碼如下:
var sendRequest=function(){}
sendRequest.prototype={
.............................
.............................
beginSend:function(){
//使循環函數里的this指向本對象,而不是全局對象
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="...."
//如果待發送的數據不為空,則將取出一條數據發到后臺
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()函數里,我們可以正常使用this來引用當前對象,使用當前對象的變量和方法,這樣豈不是很方便?

JavaScript技術javascript讓setInteval里的函數參數中的this指向特定的對象,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 欧美激情片在线观看 | 韩国美女一区二区 | 久久久中文字幕日本 | 伊人免费| 欧美激情一区二区三区在线播放 | 爽天天天天天天天 | 一区二区三区四区五区 | 精品香蕉一区二区三区 | 麻豆高清视频 | 最新99国产成人精品视频免费 | 国内精品91最新在线观看 | 成人影院观看 | 国产欧美亚洲精品 | 大量国产激情视频在线观看 | 永久免费观看午夜视频在线 | 亚洲免费视频一区 | 国产精品视频区 | 2022免费国产精品福利在线 | 亚州综合激情另类久久久 | 91精品91| 日本视频网站在线www色 | 亚洲一区二区中文字5566 | 四虎永久在线精品免费观看地址 | 日本老年人精品久久中文字幕 | 亚洲一区二区中文字幕 | 19国产精品麻豆免费观看 | 色多多视频官网 | 日韩一区二区免费看 | 伊人青草 | 在线亚洲网站 | 欧美一级一片 | 国产三级网站在线观看 | 日韩美女一级片 | 狠狠色伊人亚洲综合第8页 狠狠色伊人亚洲综合网站l | 精品极品三级久久久久 | 国产在线更新 | 国产精品午夜免费观看网站 | 91精品观看91久久久久久 | 亚洲第一中文字幕 | 国产高清免费视频 | 久久国产偷|