【问题标题】:javascript asynchronuous functionsjavascript异步函数
【发布时间】:2017-08-01 20:47:05
【问题描述】:

我是 javascript 的新手,我想使用 google maps api 检查一些数据,但是这种异步执行的函数让我很生气,而且我真的不明白回调是如何工作的。试过了,但是没用。

function initMap(a, callback) {
    var service = new google.maps.DistanceMatrixService();
    service.getDistanceMatrix({
        origins: [punktpocz[a], punktpocz[a + 1]],
        destinations: [punktkonc[a], punktkonc[a + 1]],
        travelMode: 'DRIVING',
        unitSystem: google.maps.UnitSystem.METRIC,
        avoidHighways: false,
        avoidTolls: false
    }, function (response, status) {
        if (status !== 'OK') {
            alert('Error was: ' + status);
        } else {
            var originList = response.originAddresses;
            var destinationList = response.destinationAddresses;
            for (var i = 0; i < originList.length; i++) {
                var results = response.rows[i].elements;
                for (var j = 0; j < results.length; j++) {
                    theDiv.innerHTML += originList[i] + ' to ' + destinationList[j] +
                        ': ' + results[j].distance.text + ' in ' +
                        results[j].duration.text + '<br>';
                    wynik.push({ odl: results[j].distance.text, czas: results[j].duration.text });
                }
            }
            callback();
        }
    });
}

在第二个函数中:

for(i=0;i<czasmax;i++){     
    ...
    punktpocz.push(kie[id-1]);
    punktkonc.push(biz[parseInt(zleceniajava[z+1])]);
    punktpocz.push(biz[parseInt(zleceniajava[z+1])]);
    punktkonc.push( zle[ parseInt(zleceniajava[z])] );

    initMap(i*2,function(){
        console.log('huzzah, I\'m done!');
     });
     ...        
    }

我希望脚本等到 initmap 完成后再继续,但它似乎不起作用。

【问题讨论】:

    标签: javascript callback return


    【解决方案1】:

    你可能会考虑使用 Promise(我之前也有类似的问题:Javascript Promise/Then Example)或使用 async.js

    (Node.js | MongoDB count(): Getting Count Before and After Inserting Data)

    【讨论】:

      猜你喜欢
      • 2018-09-19
      • 1970-01-01
      • 1970-01-01
      • 2012-02-25
      • 2014-10-28
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多