У меня есть следующий код в контроллере javascript. Функции работают, когда вызываются независимо и асинхронно из представления. Однако я хочу, чтобы назвать их синхронно на странице загрузки, как возвращаемое значение из первой функции используется в вызове для второй функцииУгловое обещание не работает синхронно
$scope.function1= function() {
$http({
url: '/Class/method1/',
method: 'GET'
}).success(function (data) {
$scope.mygrid= data.data;
$scope.myvalue= $scope.mygrid[0];
});
};
$scope.function2= function() {
$http({
url: '/class/method2/',
method: 'POST',
params: { myValue: $scope.myvalue }
}).success(function (data) {
$scope.myValue2 = data.data;
});
};
var initialize = function() {
var defer = $q.defer();
defer.promise
.then(function() {
$scope.function1();
})
.then(function() {
$scope.function2();
})
defer.resolve();
};
initialize();
На второй вызов $ scope.myvalue равна нулю. Данные были возвращены из функции 1, поэтому единственное, что я могу думать, это то, что function2 вызывается слишком рано. Любые указатели? :-)
Обещание никогда не синхронно. [Обещания не волшебство] (http://stackoverflow.com/a/22562045/1048572). Вам нужно «вернуть» их из обратных вызовов «then» и из вашей области «functionN's», иначе они не смогут знать, что вы хотите что-то ждать. – Bergi
, если вы хотите, чтобы функция2 запускалась после функции1, она должна быть вызвана успешным выполнением функции 1 или где-то еще, после проверки функции1 возвращены ожидаемые данные. –