四虎精品视频-四虎精品成人免费网站-四虎黄色网-四虎国产视频-国产免费91-国产蜜臀97一区二区三区

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指向特定的對象,轉載需保留來源!

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

主站蜘蛛池模板: 左航个人资料| 情欲狂欢h版| 成人在线播放网站| trainspotting| 新三国第95集完整版| 美妙天堂第三季| 麻豆视频观看| 六一儿童节对联七字| 张静初吴彦祖演的门徒| 花式特殊符号可复制| 电影《uhaw》免费观看| 代高政最新短剧| 实用咒语大全| 娄际成| 被调教的女人2| 直播斯诺克直播间| 经典常谈阅读笔记| 安泽豪个人资料| 新娘大作战angelababy| 珠帘玉幕一共多少集| 格子论文| 科洛弗| 1905电影网| 小矮人在线观看完整版| 进击的巨人最终篇| 格伦鲍威尔| 《假期》电影| 假面骑士电王| 高志鹏| 色戒 在线| 爱在线观看| 啊啊操| 黄梅戏龙女全剧播放| 保镖1983| 成人免费视频观看视频| 佩佩猪| 黑龙江卫视节目| 女脱衣| 黑凤凰电视剧剧情介绍| cgtn news在线直播| 美女mm免费视频|