加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

angularjs – 在加载资源之前等待承诺解析

发布时间:2020-12-17 08:32:57 所属栏目:安全 来源:网络整理
导读:我的一个AngularJS控制器包含以下行: api.tickets.query() api模块包含: angular.module('myapp.api',[ 'ngResource']).factory('api',function($resource,applicationsService) { function fetchAppId() { return applicationsService.getCurrentApp(); }
我的一个AngularJS控制器包含以下行:
api.tickets.query()

api模块包含:

angular.module('myapp.api',[
  'ngResource'
])

.factory('api',function($resource,applicationsService) {

  function fetchAppId() {
    return applicationsService.getCurrentApp();
  }

  return {
    tickets: $resource('tickets',{
      applicationId: fetchAppId
    }),...
  }

applicationsService.getCurrentApp()自己进行$http调用.所以你也许可以看到问题 – 这个调用可能在fetchAppId()返回时没有得到解决.

我怎么能绕过这个?

让我们说通过异步方式从applicationsService返回的数据是:
var data = [
    {
        "PreAlertInventory": "5.000000","SharesInInventory": "3.000000","TotalSharesSold": "2.000000"
    }

和applicationsService工厂返回承诺:

.factory('applicationsService',['$resource','$q',$q) {
    var data = [
    {
        "PreAlertInventory": "5.000000","TotalSharesSold": "2.000000"
    }
    ];   

       var factory = {
            getCurrentApp: function () {
                var deferred = $q.defer();   

              deferred.resolve(data);

                return deferred.promise;
            }
        }
        return factory;
}]);

我会打电话给api.tickets()

$scope.data = api.tickets();

但是我们的api服务看起来像:

.factory('api',applicationsService,$q,$timeout) {

  function fetchAppId() {      
      return applicationsService.getCurrentApp();
  }

  return {
 tickets: function() {
         var deferred=$q.defer();
        fetchAppId().then(function(data) { // promise callback
            $timeout(function(){         // added dummy timeout to simulate delay
                    deferred.resolve(data);    
                },3000);                    
        });
        return deferred.promise;
     }
   }
});

演示Fiddle

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读