1

かなりうまく機能しているサードパーティの API からユーザーのリストを取得しています。ただし、クリックしてユーザーの詳細を表示するときに、キャッシュされたユーザーのコレクション (minimongo) からの結果を使用したいと思います。それ以外の場合は、データを取得するために別の API 呼び出しを行います。

ただし、ユーザーの詳細ルートで少し奇妙なことが起こっています。User.findOne(this.params._id) の結果をログに記録すると、User オブジェクトがログに記録され、次に「undefined」がログに記録されます。

これは可能ですか、それとも訪問者がユーザー詳細ページを表示するたびに API 呼び出しを行う必要がありますか?

ルート:

Router.route('/users', {
    name: 'usersList',
    waitOn: function() {
        Meteor.subscribe('usersGet');
    }
});
Router.route('/users/:_id', {
    name: 'userPage',
    data: function() {
        var user = Users.findOne(this.params._id);
        // Logic to determine if user is found or a call to the API is required
        // Logging the results to the console initially displays the user object, but then displays undefined
        return user;
    }
});

コレクション:

// lib/collections/users.js
Users = new Mongo.Collection('users');

// server/users.js
Meteor.publish('usersGet', function () {
    var self = this;

    try {
        var response = HTTP.call("GET", "http://api.com/users", {
            headers: {
                // headers...
            }
        });

        _.each(response.data.users, function (user) {
            self.added('users', user.id, user);
        });

        self.ready();
    } catch(e) {
        // handle errors
    }
});

ユーザーページ: (ヘルパーも作成しようとしましたが、同じ結果が得られました)

Template.userPage.helpers({
    user: function() {
        var user = Users.findOne(this._id);
        console.log(user); // I initially see the user object the server retrieved earlier logged 3 times, but then it logs "undefined"
    }
});
4

0 に答える 0