JavaScript

超轻量级php框架startmvc

解决angularjs中同步执行http请求的方法

更新时间:2020-07-21 04:00:01 作者:startmvc
如下所示:self.tableParams=newNgTableParams({},{getData:function(params){$http.post("rest/staff/page",$scope.req).s

如下所示:


self.tableParams = new NgTableParams({}, {
 getData: function (params) {
 $http.post("rest/staff/page", $scope.req).success(function (data) {
 if (data != null && data != undefined) {
 $scope.staffs = data.data;
 params.total($scope.totalPage);
 }
 }).error(function (data) {
 $("#serverErrorModal").modal({show: true});
 });
 
 return $scope.staffs;
 }
});

上面这个示例中,getData方法要得到通过$http请求返回的值,然而在angularjs中$http永远都是异步的,也就是说return的值将一直为空;

网上的例子都是通过$q,promise来实现,我试了但是不行,应该是我自己的问题

然后突然想到$http本身就返回一个promise对象,何不直接使用?!代码如下


self.tableParams = new NgTableParams({'count': 10} , {
 getData: function (params) {
 var promise = $http.post("rest/staff/page", $scope.req);
 return promise.then(function (resut) {
 var response = resut.data;
 var total = response.otherData[0];
 params.total(total);
 return response.data;
 });
 
 }
});

直接这样return就可以实现同步获取数据了~

以上这篇解决angularjs中同步执行http请求的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

angularjs 同步执行 http