0

私は 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);
  }
});
4

1 に答える 1

0

によってすでにロードされているモデル内のPostRouteポストを探すように、 を変更できますPostsRoute。見つかった場合はそれを返し、それ以外の場合は ajax 呼び出しを介してロードしようとします。

App.PostRoute = Ember.Route.extend({
  model: function(params) {
    var post = this.modelFor("posts").findBy("id",parseInt(params.post_id)); 
    if(Em.isEmpty(post)){
      return App.Post.find(params.post_id);    
    }else{
      return post;
    }

  }
});
于 2014-01-26T22:20:09.657 に答える