编辑
对不起,我没有第一次进入这个问题。 (对于PlayerResults),我们从来没有试过这个(所以不确定它是否可能),但也许你也可以应用一个ListView到<td>
标签(对于结果),就像它在<tr>
标签中完成一样。
的Java:
List<PlayerResult> players = // ...
ListModel<PlayerResult> playersModel = new ListModel<PlayerResult>(players);
ListView<PlayerResult> list = new ListView<PlayerResult>("list", playersModel) {
@Override
protected void populateItem(ListItem<PlayerResult> item) {
Label name = new Label("name", new PropertyModel<String>(item.getModel(), "player.name"));
Label surname = new Label("surname", new PropertyModel<String>(item.getModel(), "player.surname"));
Label results= new Label("results", item.getModelObject().getResults().size());
ListView<Result> scoreList= new ListView<Result>("scoreList", item.getModelObject().getResults()){
@Override
protected void populateItem(ListItem<Result> resultItem) {
item.add(new Label("score", new PropertyModel<Integer>(resultItem.getModel(), "scoreValue ? ")));
}
}
// ...
item.add(name);
item.add(surname);
item.add(results);
item.add(scoreList);
// ...
}
}
HTML:
<table>
<tr wicket:id="list">
<td><span wicket:id="name">[name label]</span></td>
<td><span wicket:id="surname">[surname label]</span></td>
<td><span wicket:id="results">[results label]</span></td>
<!-- and now variable number of tds -->
<td wicket:id="scoreList">
<span wicket:id="score"></span>
</td>
</tr>
</table>
你尝试过这么远吗?我会使用DataTable或AjaxFallbackDefaultDataTable。 – 2012-08-17 07:29:06
我遵循这个例子:http://www.wicket-library.com/wicket-examples/repeater/wicket/bookmarkable/org.apache.wicket.examples.repeater.AjaxDataTablePage?0但我不知道如何传递列表的类成列 – hudi 2012-08-17 07:32:20