私は ember の初心者で、WordPress JetPack json API の Ember データを使用せずにテストを作成しました: http://broerse.net/ember/wp3/#/posts (1 つの JetPack 呼び出しになります)
http://broerse.net/ember/wp3/#/posts/3787のような URL を介して投稿にアクセスする場合 、findAll で作成されたオブジェクトから「id」を持つ投稿を返す方法がわかりません。JetPack から「id」で特定の投稿を再度取得することになりました。以下のコードで 'find' を書き直して、JetPack を 2 回呼び出す必要がないようにする方法はありますか?
App = Ember.Application.create();
App.Router.map(function() {
this.resource('posts', function() {
this.resource('post', { path: ':post_id' });
});
});
App.Post = Ember.Object.extend();
App.Post.reopenClass({
findAll: function() {
return Ember.$.ajax({ url: 'http://public-api.wordpress.com/rest/v1/sites/58826716/posts/?number=10', dataType: "jsonp", type: 'GET' }).then(function(data) {
return data.posts.map(function(post) {
post['id'] = post['ID'];
delete post['ID'];
return App.Post.create(post);
});
});
},
find: function(id) {
return Ember.$.ajax({ url: 'http://public-api.wordpress.com/rest/v1/sites/58826716/posts/' + id + '/', dataType: "jsonp", type: 'GET' }).then(function(post) {
post['id'] = post['ID'];
delete post['ID'];
return App.Post.create(post);
});
}
});
App.PostsRoute = Ember.Route.extend({
model: function() {
return App.Post.findAll();
}
});
App.PostRoute = Ember.Route.extend({
model: function(params) {
return App.Post.find(params.post_id);
}
});