1

我是 Ember 的新手,我正在尝试使用 Ember 视图来观察控制器中的属性变化。我可以记录视图,但是当属性更改时处理程序不会触发。

我基本上是在尝试学习当用户单击删除记录时从视图中删除项目的 Ember 方法。我还没有找到一个很好的指南。任何建议表示赞赏。

如果我遗漏了什么,请告诉我。提前致谢!

(这是一个继承的代码库;我们还没有准备好升级 Ember。)

Ember v1.0.0-rc.3

路线

this.resource('posts');
App.PostsRoute = App.AuthenticatedRoute.extend({ // extension of Em.Route
  model: function() {
    return App.Post.list(); // returns a list of posts
  },

  events: {
    // renders a modal in the post context
    showDeleteModal: function(model) {
      this.render('modals/_confirmation', {
        into: 'posts',
        outlet: 'modal',
        controller: 'post'
      });

      this.controllerFor('post').set('model', model);
    }
  }
});

控制器

App.PostsController = Em.ObjectController.extend(App.PagedTable, Ember.Evented, {
  // ...
});

App.PostController = Em.ObjectController.extend({
  foo: false,

  del: function() {
    this.set('foo', true);
  }
});

看法

App.PostsView = Em.View.extend();

App.PostView = Em.View.extend({
  didInsertElement: function() {
    console.log('Inserted!');
  },

  test: function() {
    console.log('Observed!');
  }.observes('controller.foo')
});

模板

{{#each data in currentDataBlocks itemController="post" itemViewClass="App.PostView"}}
  <tr>
    <td>Stuff</td>
    <td>Stuff</td>
    <td>Stuff</td>
    <td>Stuff</td>
    <td><button class="icon-trash" {{action showDeleteModal data}}></button></td>
  </tr>
{{/each}}

<!-- ... -->

{{outlet modal}}
4

1 回答 1

5

在我看来,管理视图中的项目列表的最佳方法是创建列表的属性,仅包含需要呈现的项目,并在视图中迭代此列表。

使用您的示例(为简单起见进行了一些更改),我将执行以下操作:

控制器:

PostsController = Em.ObjectController.extend(....
    fooDataBlocks: function(){
        return this.get("currentDataBlocks").filter(function(dataBlock){
            return dataBlock.get("foo");
        }
    }.property("currentDataBlocks.@each.foo")
);

模板:

{{#each data in fooDataBlocks...}}
   ...
{{/each}}

根据经验,如果可能的话,总是更喜欢使用属性而不是观察者。这样,该值仅在需要时才被缓存和计算,而不是在每次更改时。

于 2013-09-17T06:56:15.953 回答