编程语言
首页 > 编程语言> > javascript – 从promise返回的对象是未定义的

javascript – 从promise返回的对象是未定义的

作者:互联网

我试图将getstream API包装在角度服务(工厂)中

这是我的代码:

.factory('FeedStream', function($http, $q) {

    var client = stream.connect('xxxxxxxxxxx');

    return {
        feed : function() {
            $http.get('/api/feed/auth/')
            .success(function(auth) {

                var user_feed = client.feed('user', auth.user, auth.token);
                console.log(user_feed.get());

                user_feed.get().then(function(data) { 
                    console.log(data);
                    return data;
                })
            })
        },
    }

首先,我使用端点/ api / feed / auth /从我的服务器获取user_id和auth令牌.这个数据以有角度的承诺返回.

接下来,我使用此数据调用getstream api来获取user_feed对象.如果我返回此对象(user_feed),则在控制器中未定义.如果我在服务中将其打印到控制台,则它具有正确的值.我注意到在返回后打印发生了半秒左右.为什么这个变量的赋值是异步发生的?

现在,如果我在console.log语句中调用此user_feed对象上的get方法,则会打印出一个Javascript promise对象.如果我返回user_feed.get(),它会将undefined返回给控制器.如果我在上面的代码中在服务中调用它,并在promise then语句中返回数据对象,则将undefined返回给控制器.但是,如果我打印数据对象,它具有正确的值.

为什么我不能从此服务返回任何对象?我错过了使用承诺的一些基本方面吗?

解决方法:

您尚未返回Feed promise对象,并且尚未正确地从Feed方法返回数据.所以为了达到同样的目的,请使用.then over $http来保持承诺链接

return {
    feed : function() {
        //return `$http.get` promise
        return $http.get('/api/feed/auth/')
        .then(function(response) {
            var auth = response.data;
            var user_feed = client.feed('user', auth.user, auth.token);
            console.log(user_feed.get());
            //return `$http.get` to return internal promise
            return user_feed.get().then(function(data) { 
                console.log(data);
                return data;
            })
        })
    },
}

调节器

FeedStream.feed().then(function(data){
   console.log("data returned by user feed", data)
})

标签:angular-promise,javascript,angularjs,promise,getstream-io
来源: https://codeday.me/bug/20190829/1759216.html