0

ArrayController.itemController使用 ObjectController 将每个单独的项目包装在控制器的内容中。是否有类似物ObjectController可以将属性的值包装在控制器中?

如果在 上没有直接的类比,那么使用将模型的属性包装在另一个控制器中ObjectController的推荐方法是什么?ObjectController

这是我一开始在做的事情:

App.BlogPostController = Ember.ObjectController.extend({
  comments: function(){
    return App.CommentsController.create({
      model: this.get('model.comments')
    });
  }.property()
});

这很简单,但如果model.comments被替换它就会崩溃。因此,我对其进行了更改以响应更改:

App.BlogPostController = Ember.ObjectController.extend({
  comments: function(){
    var commentsController = this.get('_commentsController');
    if (!commentsController){
      commentsController = App.CommentsController.create();
      this.set('_commentsController', commentsController);
    }
    commentsController.set('model', this.get('model.comments'));
    return commentsController;
  }.property('model.comments')
});

这似乎可行(尽管我想我还没有发现一些问题),但感觉相当不雅。有没有更好的方法来做到这一点?

编辑

另一种选择是:

App.BlogPostRoute = Ember.Route.extend({
  model: function() {
    return {...};
  },
  setupController: function(controller, model){
    this._super(controller, model);
    this.controllerFor('comments').set('content', model.get('comments'));
  }
});

App.BlogPostController = Ember.ObjectController.extend({
  needs : ['comments']
});

这看起来可能有点“Ember-istic”,但也有点复杂,需要将模板引用从 更改{{comments}}{{controllers.comments}}. 所以仍然感觉应该有一些更直接但仍然惯用的东西......?

4

1 回答 1

0

{{render 'templateName' model.property}}

该属性将是 TemplateNameController 的模型。 templateName是将用于渲染的模板。

于 2013-10-25T01:15:43.173 回答