我有一个可编辑的Vaadin表,它有一个复选框列。如何将复选框表列与数据库绑定?
当该项目的条件是getISACTIVE = 1
(长型,取自数据库),我希望复选框被检查。另一方面,当我改变复选框的值时,我希望ISACTIVE
条件相应地改变(setISACTIVE=1
被选中,setISACTIVE=0
不被选中)。
到现在为止,我试图映射复选框,但仍即使条件= 1
任何想法,我应该怎么办复选框不检查?
table.addGeneratedColumn("Is Active", new Table.ColumnGenerator() {
private static final long serialVersionUID = 1L;
@Override
public Object generateCell(final Table source, final Object itemId,
Object columnId) {
final CheckBox checkBox = new CheckBox("");
//ITERATE THROUGH DATABASE, THEN getPS_SECTION that is the ID Bean Property
for (int i = 0; i < list.size(); i++) {
PS_SECTION section = list.get(i);
Long sc = section.getPS_SECTION();
FillIt(sc,checkBox);
if (section.getISACTIVE() == 1L) {
value = true;
CheckIt(sc,value);
}
else if(section.getISACTIVE() == 0L){
value = false;
CheckIt(sc,value);
}
}
checkBox.addValueChangeListener(new ValueChangeListener() {
@Override
public void valueChange(ValueChangeEvent event) {
Boolean isTrue = checkBox.getValue();
if (isTrue){
isChecked = true;
Notification.show("Is activated");
//setISACTIVE = 1
}
else{
isChecked = false;
Notification.show("Is deactivated");
//setISACTIVE = 0
}
}
});
return checkBox;
}
});
table.setTableFieldFactory(new DefaultFieldFactory() {
public Field<?> createField(Container container, final Object itemId, Object propertyId, Component uiContext) {
if (CHECKBOX_COLUMN.equals(propertyId)) {
CheckBox field1 = new CheckBox();
field1.setImmediate(true);
}
return super.createField(container, itemId, propertyId, uiContext);
}
});
而且这里的方法FillIt()
和CheckIt()
:
private void CheckIt(Long id, Boolean value) {
CheckBox checkBox = itemIdToCheckbox.get(id);
checkBox.setValue(value);
}
private void FillIt(Long id, CheckBox checkBox) {
itemIdToCheckbox.put(id,checkBox);
}
//When itemIdToCheckBox is
protected Map<Long, CheckBox> itemIdToCheckbox = new LinkedHashMap<Long, CheckBox>();
是否有可能使用vaadins网格组件而不是?结合一个'BeanItemContainer',您的复选框用例应该很简单。 – JDC
@JDC不幸的是,这是不可能的,因为我们使用的vaadin版本不支持网格。谢谢你! – natso