我对ListMultipleChoice有疑问,无论如何在ajax链接提交之前获取所选项目,例如因为我不会每次都刷新我的页面。
谢谢!
// Liste des partenaires de l'offre.
final ListMultipleChoice partenairesSelec =
new ListMultipleChoice("partenairesSelec", new Model((Serializable) partenairesSelected), new PropertyModel(
offre,
"partenaires"), renderer);
// Liste des domaines.
final DropDownChoice makes = new DropDownChoice("domaines", new PropertyModel(this, "selectedMake"), makeChoices) {
@Override
protected CharSequence getDefaultChoice(Object selected) {
return new ArrayList<String>(modelsMap.keySet()).get(0);
}
};
// Liste des partenaires disponibles.
final ListMultipleChoice partenairesChoice =
new ListMultipleChoice("partenaires", new Model((Serializable) partenairesSelection), modelChoices, renderer);
// Action associé au changement du domaine.
makes.add(new AjaxFormComponentUpdatingBehavior("onchange") {
@Override
protected void onUpdate(AjaxRequestTarget target) {
target.addComponent(partenairesChoice);
}
});
// Bouton ajouter.
Button ajout = new Button("ajout") {
@Override
public void onSubmit() {
if (partenairesSelection.size() != 0) {
for (Partenaire p : partenairesSelection) {
if (!partenairesSelected.contains(p)) {
offre.getPartenaires().add(p);
modelsMap.get(selectedMake).remove(p);
}
}
offre.setPartenaires(sortPartenaireList(offre.getPartenaires()));
}
}
};
// Bouton supprimer.
Button suppr = new Button("suppr") {
@Override
public void onSubmit() {
List<Partenaire> tmp = new ArrayList<Partenaire>();
if (partenairesSelected.size() != 0) {
for (Partenaire p : partenairesSelected) {
if (!partenairesSelection.contains(p)) {
Long id = p.getPartnerDomainId();
tmp.add(p);
for (String key : modelsMap.keySet()) {
if (modelsMap.get(key).size() > 0 && modelsMap.get(key).get(0).getPartnerDomainId() == id) {
modelsMap.get(key).add(p);
}
}
}
}
for (Partenaire p : tmp) {
offre.getPartenaires().remove(p);
}
offre.setPartenaires(sortPartenaireList(offre.getPartenaires()));
}
}
};
答案 0 :(得分:1)
AjaxFormChoiceComponentUpdatingBehavior
是专为此而设计的课程。将它附加到您的组件,您将在选择更改的任何位置获得AJAX更新。
答案 1 :(得分:1)
ListMultipleChoice的AjaxFormChoiceComponentUpdatingBehavior 不起作用!
我还搜索了一个很好的工作解决方案,过了一段时间后,我找到了一个非常好的教程,面对两个ListMultipleChoice元素的情况,并添加/删除按钮以在两个多个选择框之间交换内容:
http://blog.xebia.com/2008/03/25/wicket-and-list-choice-transfers/
他们使用AjaxButtons执行此操作而不提交表单。