如何在angular js中进行同步http请求 [英] how to make synchronous http request in angular js
本文介绍了如何在angular js中进行同步http请求的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
如何在 AngularJS 中阻止 http 请求,以便我可以在下一行使用 $http 响应?
How to make blocking http request in AngularJS so that i can use the $http response on very next line?
在下面的示例中,$http
对象不会将结果返回到下一行,因此我可以将此结果传递给 fullcalender()
,一个 JavaScript 库,因为 $scope.data
返回空值.
In the following example, $http
object doesn't return the result to the next line so that I can pass this result to fullcalender()
, a JavaScript library, because $scope.data
returns blank value.
这是示例代码:
$http.get('URL').success(function(data){
$scope.data = data;
});
$.fullCalender({
data: $scope.data
});
推荐答案
您可以使用 承诺.
这是一个例子:
$scope.myXhr = function(){
var deferred = $q.defer();
$http({
url: 'ajax.php',
method: 'POST',
data:postData,
headers: {'Content-Type': 'application/x-www-form-urlencoded'}
})
//if request is successful
.success(function(data,status,headers,config){
//resolve the promise
deferred.resolve('request successful');
})
//if request is not successful
.error(function(data,status,headers,config){
//reject the promise
deferred.reject('ERROR');
});
//return the promise
return deferred.promise;
}
$scope.callXhrAsynchronous = function(){
var myPromise = $scope.myXhr();
// wait until the promise return resolve or eject
//"then" has 2 functions (resolveFunction, rejectFunction)
myPromise.then(function(resolve){
alert(resolve);
}, function(reject){
alert(reject)
});
}
这篇关于如何在angular js中进行同步http请求的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文