1

我面临一个问题。我正在使用 angular 1.2RC3 和 ui-route 0.2。如果我解决了一个正在执行同步返回的函数,它就可以工作。使用 Promise,控制器在解决 Promise 之前被初始化。

http://plnkr.co/edit/feXHNaGsXwpXDBXkxLZx

angular.module('srcApp', ['ui.router'])
    .config(function ($stateProvider, $urlRouterProvider) {

        $urlRouterProvider.otherwise('/');

        var userResult = {
            id : 'userid',
            displayName : 'displayName'
        };

        var getUserPromise = function ($q, $timeout, $log) {

            var defer = $q.defer;
            $timeout(function () {
                $log.log('promise resolved');
                defer.resolve(userResult);
            }, 2000);
            return defer.promise;
        };

        $stateProvider.state('test', {
            url: '/',
            template: '<div>{{user.displayName}}</div>',
            controller: 'testCtrl',
            resolve : {
              user: getUserPromise
            }
        });
    });


    var testCtrl = angular.module('srcApp').controller('testCtrl', function ($scope, $http, $log, user) {
        $log.log("test controller init");
        $log.log("test controller user=" + user);
        $scope.user = user;
    });
4

1 回答 1

2

奇怪......这几乎就是我在应用程序中逐行所做的。

已解决:http ://plnkr.co/edit/oC5wK8aDcq82mWl8ES6l?p=preview

您输入:

$q.defer

代替:

$q.defer()
于 2013-10-27T02:52:33.480 回答