gpt4 book ai didi

angularjs - 如何在Angular JS中发出同步http请求

转载 作者:行者123 更新时间:2023-12-02 22:16:14 25 4
gpt4 key购买 nike

如何在 AngularJS 中阻止 http 请求,以便我可以在下一行使用 $http 响应?

在下面的示例中,$http 对象不会将结果返回到下一行,以便我可以将此结果传递给 JavaScript 库 fullcalender() ,因为 $scope.data 返回空白值。

这是示例代码:

$http.get('URL').success(function(data){
$scope.data = data;
});

$.fullCalender({
data: $scope.data
});

最佳答案

您可以使用promises为此。

这是一个例子:

$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)
});

}

关于angularjs - 如何在Angular JS中发出同步http请求,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26750814/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com