かなりうまく機能しているサードパーティの 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"
}
});