视图排序和过滤:GlazedList 排序和过滤+ JTable vs Glazed 事件列表+JXTable

发布于 2024-12-11 08:34:54 字数 1141 浏览 4 评论 0原文

我想创建具有排序和过滤功能的用户视图(表)。我使用 EventList (Glazed Lists) 作为 EventTableModel 的源。 GlazedLists 中还有排序列表和一些过滤项,因此我可以使用它们来创建视图。但我发现 JXTable 它有排序和过滤的方法,这就是我希望它工作的方式:排序和过滤必须提供 UI 组件和模型才能保存数据:

EventList<Item> source=new BasicEventList<Item>();
TableModel model=new DefaultEventTableModel<Item>(source,tableFormat); // It'll be
//perfect if I could create model without tableFormat,
//because it's presentation of data,
//but in GlazedLists I can't :( ...
JTalbe ui=new JXTable(model); // UI with sorting and filtering

但是 GlazedLists 还提供 SortedList (带有排序的 EventList 的装饰器),并且一些过滤方法。

EventList<Item> source=new BasicEventList<Item>();
SortedList<Item> sortedSource=new SortedList<Item>(source,comparator);
TableModel model=new DefaultEventTableModel<Item>(sortedSource,tableFormat); 
// model with sorting... not very beautifull for me, but what do you think?

JTable ui=new JTable(model); // UI with sorting provided by model

问题是:哪种模型更好。或者也许两者都错了,创建视图有什么用呢?

I want to create user views (tables) with sorting and filtering capabilities. I use EventList (Glazed Lists) as source for EventTableModel. There are also Sorted List and some filtering items in GlazedLists, so I can use them for creating view. But I found JXTable and it has methods for sorting and filtering, and this how I want it to work: sorting and filtering must provide UI component and model just can hold data:

EventList<Item> source=new BasicEventList<Item>();
TableModel model=new DefaultEventTableModel<Item>(source,tableFormat); // It'll be
//perfect if I could create model without tableFormat,
//because it's presentation of data,
//but in GlazedLists I can't :( ...
JTalbe ui=new JXTable(model); // UI with sorting and filtering

But GlazedLists also provide SortedList (decorator for EventList with Sorting), and some filtering methods.

EventList<Item> source=new BasicEventList<Item>();
SortedList<Item> sortedSource=new SortedList<Item>(source,comparator);
TableModel model=new DefaultEventTableModel<Item>(sortedSource,tableFormat); 
// model with sorting... not very beautifull for me, but what do you think?

JTable ui=new JTable(model); // UI with sorting provided by model

And the question is: what model is better. Or maybe both are wrong, and what do use for creating views?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

情愿 2024-12-18 08:34:54

如果您使用 DefaultEventTableModel 一切都可以。当模型在 EventList 源上注册排序器时。它是在内部完成的,如您的第二个清单中所示。如果您手动注册排序器,则必须实现所有代码才能更改比较器(例如 asc、desc)。当尝试使用过滤时,它是相同的,但 JXTable 恕我直言不支持此机制,因此您必须以自己的方式执行此操作。

In case you use the DefaultEventTableModel everthing is ok. As the model registers sorters on the EventList source. It's done internally as in your 2nd listing. In case you register the sorters manually, then you have to implement all the code in order to change the comparator (e.g. asc, desc). When trying to use filtering its the same, but the JXTable imho doesn't support a mechanism for this, so you have to do this in your own way.

橙幽之幻 2024-12-18 08:34:54

我投票给 GlazedLists,因为它有效。是的,与表一起使用的 TableModel 与视图紧密耦合,但是您将该表模型与源数据解耦。

GlazedLists 的排序和过滤功能比 JXTable 上的灵活得多。只需确保您没有同时打开它们,否则事情会变得混乱。下面是我在 JXTable 中使用 SortedList 的常用代码片段:

private <T> EventTableModel<T> setupTable(JXTable table, TableFormat<T> tf, EventList<T> displayItems, SortedList<T> sortedItems)
{
    table.setColumnControlVisible(true);
    table.setSortable(false);
    table.getTableHeader().setDefaultRenderer(new JTableHeader().getDefaultRenderer());
table.setAutoCreateRowSorter(false);
table.setRowSorter(null);

    EventTableModel<T> etm = new EventTableModel<T>(displayItems, tf);
    table.setModel(etm);

    TableComparatorChooser.install(table, sortedItems, AbstractTableComparatorChooser.SINGLE_COLUMN);
    return etm;
}

作用:

  • 打开 JXTable 右上角的列选择器小工具
  • 关闭 JXTable 的内置排序
  • 安装 GlazedLists 的排序功能,而不是
  • 使用从TableFormat

请注意,您传入两个 EventList、一个displayItems(管道末尾的列表)以及一个用于控制使用哪一列的sortedList用于排序,它在管道中可以早于 displayItems 列表。 (如果你的最后一个元素是sortedList,之后不进行任何处理,只需将列表传递两次即可。)

I vote for GlazedLists, because it works. Yes, the TableModel that you use with the table is tightly coupled to the view, but you decouple that table model from your source data.

GlazedLists' sorting and filtering features are much more flexible than the one on JXTable. Just make sure you don't have them both turned on, or things will get confusing. Here's my usual code snippet for using a SortedList with a JXTable:

private <T> EventTableModel<T> setupTable(JXTable table, TableFormat<T> tf, EventList<T> displayItems, SortedList<T> sortedItems)
{
    table.setColumnControlVisible(true);
    table.setSortable(false);
    table.getTableHeader().setDefaultRenderer(new JTableHeader().getDefaultRenderer());
table.setAutoCreateRowSorter(false);
table.setRowSorter(null);

    EventTableModel<T> etm = new EventTableModel<T>(displayItems, tf);
    table.setModel(etm);

    TableComparatorChooser.install(table, sortedItems, AbstractTableComparatorChooser.SINGLE_COLUMN);
    return etm;
}

What this does:

  • turn on the column picker gadget on the upper right of the JXTable
  • turn off JXTable's builtin sorting
  • install GlazedLists' sorting features instead
  • setup the table with an EventTableModel derived from the TableFormat

Note that you pass in two EventLists, a displayItems which is the list at the end of the pipeline, and a sortedList used for controlling which column is used for sorting, which can be earlier in the pipeline than the displayItems list. (If your last element is the sortedList, without any processing after that, just pass the list in twice.)

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文