亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

循環內的異步進程

循環內的異步進程

循環內的異步進程我正在運行以下形式的事件循環:var i;var j = 10;for (i = 0; i < j; i++) {     asynchronousProcess(callbackFunction() {         alert(i);     });}我正在嘗試顯示一系列顯示數字0到10的警報。問題在于,當回調函數被觸發時,循環已經進行了幾次迭代,并且它顯示了更高的i。關于如何解決這個問題有什么建議嗎?
查看完整描述

3 回答

?
慕標5832272

TA貢獻1966條經驗 獲得超4個贊

幾個。你可以用綁定:

for (i = 0; i < j; i++) {
    asycronouseProcess(function (i) {
        alert(i);
    }.bind(null, i));}

或者,如果您的瀏覽器支持放任(它將出現在下一個ECMAScript版本中,但是Firefox已經支持它一段時間了),您可以擁有:

for (i = 0; i < j; i++) {
    let k = i;
    asycronouseProcess(function() {
        alert(k);
    });}

或者,你可以做bind手動(如果瀏覽器不支持它,但我想說在這種情況下可以實現SIM,它應該在上面的鏈接中):

for (i = 0; i < j; i++) {
    asycronouseProcess(function(i) {
        return function () {
            alert(i)
        }
    }(i));}

我通常更喜歡let當我可以使用它時(例如火狐插件),則為bind或者一種習俗競逐函數(不需要上下文對象)。


查看完整回答
反對 回復 2019-05-30
  • 3 回答
  • 0 關注
  • 572 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號