0

我是一名 ember 初学者,并为 WordPress JetPack json API 创建了一个没有 Ember 数据的测试:http://broerse.net/ember/wp3/#/posts 导致一个 JetPack 调用)

如果您通过http://broerse.net/ember/wp3/#/posts/3787之类的 URL 访问帖子, 我不知道如何从使用 findAll 创建的对象中返回带有“id”的帖子。我最终再次从 JetPack 中通过 'id' 获取了特定的帖子。有没有办法在下面的代码中重写“查找”,所以不需要两个 JetPack 调用?

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 回答