0

そのため、関数の結果を次の関数に渡す手順として非同期ウォーターフォールを使用しています。現在、クエリの結果としてユーザーにプッシュを呼び出す際に問題が発生しています。

これが私のコードです:

    exports.contactList = function(req, res) {

    async.waterfall([
    function(callback) {

        Friend.findOne({userId: req.signedCookies.userid}, function(err, users) {
            var friends = [];
            if(err) {throw err};
            for(var i = 0; i < users.friendStatus.length; i++) {
                if(users.friendStatus[i].status === 3) { friends.push(users.friendStatus[i])};  
            }
            //console.log(friends);
            callback(null, friends);
        });


        },

        function(friends, callback) {
            var friendsinfo = [];

            for(var i = 0; i < friends.length; i ++) {
                async.each(friends, function(friend, next) {
                //friendsinfo.push(friend.favorites)


                User.findOne({_id: friend.fuId}, function(err, user) {
                    if (err) { console.log(err); };
                        var object = {'fav': friend.favorites, 'user': user};
                        friendsinfo.push(object);
                        next(err);
                }); 
            }, function(err) {
                console.log('friendsINFO');
                console.log(friendsinfo);
                callback(err, friendsinfo);
            });
            }








        }
    ],

    function(err, results) {
        console.log('RESULTS');
        console.log(results);
        res.render('contactList', {title: 'Weblio', Friends: results});
    });

};

Console.log(user) は実際にユーザーを出力します。配列 friendsInfo は未定義として表示されます。

4

2 に答える 2