微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

我的一个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

原文地址:https://www.jb51.cc/angularjs/141326.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐