我的最终目标是拥有一个在运行时刷新其内容的JList,并且我找到了一个可以在这篇文章中发挥作用的解决方案here on SO,但我很好奇为什么我原来的想法没有。
截至目前,我有类似这样的设置并且有效:
DefaultListModel default = new DefaultListModel();
for(int i = 0; i < array.size() ; ++i){
test.addElement(array.get(i));
}
list.setModel(default);
以下是我最初的计划。我希望有一个实现ListModel的类作为参数传递,希望它能刷新JList。
SomeClass test = new SomeClass(); //Implements ListModel
list.setModel(test);
或
SomeClass test = new SomeClass(); //Implements ListModel
list = new JList(test);
这些都不会让我感到困惑。这些最后两种方法是如何工作的,代码是如此清晰。
感谢。
答案 0 :(得分:3)
如果正确实现ListModel,第一种方法应该有效。关键是当您更改需要调用的数据时:
fireContentsChanged(...);
来自AbstractListModel的(我假设你扩展)。调用此方法将告诉JList重绘自己。
第二种方法不起作用,因为您只需创建一个位于内存中的新JList组件。创建组件不会将其添加到GUI。因此,如果您使用此方法,则需要从GUI中删除原始JList,然后将新JList添加到GUI。这不是很方便,并且是不应该使用这种方法的一个很好的理由。设置模型始终是首选方法。
答案 1 :(得分:1)
第一种情况在我看来似乎是一种解决方案。你能提供一个可测试的例子吗?
第二种情况不起作用,因为你只是重用一个变量而实际上并没有改变Gui上的JList。我假设你已经在代码中添加了这个列表。
答案 2 :(得分:0)
很可能你的ListModel实现是错误的。
答案 3 :(得分:0)
为什么不使用:
DefaultListModel<String> lstList = new DefaultListModel<String>();