首页 > 解决方案 > 带参数的JS中的闭包

问题描述

我有一个像这样的对象

JSON_DATA = {
    "EVENT" : "data/sequence/sequenceEvent.json",
    "CHAT" : "data/sequence/sequenceChat.json",
}

我想加载这些值,所以我这样做

LoadJSON(JSON_DATA, function(data){
    var DATA = data;
});

function LoadJSON(jsons, callback){
    var counterLoaded = 0;
    var counterToLoad = Object.keys(jsons).length;

    var parsedData = {};
    for(var key in jsons){
        ajax.get(jsons[key], "", function(data){
            parsedData[key] = JSON.parse(data);
            counterLoaded++;
            if(counterLoaded == counterToLoad){
                callback(parsedData);
            }

        }, true)
    }
}

现在,我知道我有一个关闭问题,就像 key 总是最后一个。

但是,我在互联网上搜索,并期待一个 setTimeOut 或这样的功能

function LoadJSON(jsons, callback){
    var counterLoaded = 0;
    var counterToLoad = Object.keys(jsons).length;

    var parsedData = {};
    for(var key in jsons){
        ajax.get(jsons[key], "", (function(key){
            parsedData[key] = JSON.parse(data);
            counterLoaded++;
            if(counterLoaded == counterToLoad){
                callback(parsedData);
            }

        })(key), true)
    }
}

它不起作用,但在我的问题中,我还需要传递参数数据。

我怎样才能做到这一点?

标签: javascriptajaxloopsclosures

解决方案


关键永远是最后一个。

选项 1:使用闭包。

for (var key in jsons) {
  (function(k) {
    ajax.get(jsons[k], "", function(data) {
      parsedData[k] = JSON.parse(data);
      counterLoaded++;
      if (counterLoaded == counterToLoad) {
        callback(parsedData);
      }
    }, true);
  })(key);
}

选项 2:使用 Promise API。


推荐阅读