在sort上刷新containerView

时间:2012-07-16 20:21:11

标签: ember.js

我正在尝试在已经显示之后对其进行排序。但是,由于数组的长度不会改变而只会改变顺序,因此视图不会刷新。有关如何强制观看重新渲染的最佳做法吗?

1 个答案:

答案 0 :(得分:6)

如果您在此处获取Embers GitHub页面的最新版本:https://github.com/emberjs/ember.js/downloads它包含Ember.ArrayController,后者又使用Ember.SortableMixin。

您可以像这样定义控制器:

HS.BlogPostsListController = Em.ArrayController.create({
    content: [],
    sortAscending: false,
    sortProperties: ['postDate'],
    //the rest of your controller definition...
}

然后将视图绑定到控制器的arrangeContent属性,如下所示:

{{#view MyApp.view contentBinding="HS.BlogPostListController.arrangedContent" ...}}

这将在排序更改时(更改sortAscending或sortProperties属性时)更新视图。

如果您不想提取最新版本,请查看SortableMixin源代码,看看是否可以将其合并到您自己的应用中:https://github.com/emberjs/ember.js/blob/master/packages/ember-runtime/lib/mixins/sortable.js

编辑:你可以在GitHub上看到HS.BlogPostListController在这里:https://github.com/joachimhs/haagen-software.no/blob/master/app/controllers.js