如何解决$ q的承诺?

时间:2016-01-14 19:43:33

标签: javascript angularjs parse-platform angular-promise

我正在使用AngularJS和$ q进行承诺,我对这种用法感到困惑,我该如何解决这个问题呢?

我想在调用isLoggedInPromise()或“AUTH_REQUIRED”时返回用户。

谢谢!

    function isLoggedInPromise() {
        $q.when(userWithAllData()).then(function(user) {
            return user;
        });
        $q.when(userWithAllData()).reject(function() {
            return "AUTH_REQUIRED";
        });
    }

    function userWithAllData(){
        var deferral = $q.defer();

        var query = new Parse.Query(Parse.User);
        query.include(["info", "info.rank", "privateInfo"]);
        query.get(Parse.User.current().id).then(function (loadedUser){
            deferral.resolve( loadedUser );
        });

        return deferral.promise;
    }

1 个答案:

答案 0 :(得分:3)

当函数具有实际返回所需的所有数据时,您要做的就是在promise上调用resolve函数

在一个返回承诺的函数中,想到"解决"作为实际的退货声明。

所以你的isLoggedInPromise函数需要返回一个promise,这会使它变得冗余。任何需要用户的东西都必须等到那时。

isLoggedInPromise().then(function(result){...etc...}, function(reason){//auth needed})

如果您仍然需要isLoggedin函数,那么它应该看起来像

 function isLoggedInPromise() {
    var isLoggedIn = userWithAllData().then(
        function(user) {
            return user;
        }, 
        function(reason){
            return $q.reject("AUTH_REQUIRED")
        });    
 }

当然,您还必须在userWithAllData函数中包含一些拒绝逻辑。

相关问题