嘿伙计们,我正在尝试提供一种内联编辑带有primefaces的数据表行的可能性,但它似乎无法正常工作。我可以直观地编辑值,但是当我单击保存图标时,它不会更新更改的值...
以下是代码:
数据表:
<p:dataTable id="ticketTypePrices" var="priceCategoryTicketType"
value="#{EventInstanceController.priceCategoryTicketTypes}"
editable="true">
<p:ajax event="rowEdit" update="@this" listener="#{EventInstanceController.onEditPrices}" />
<p:ajax event="rowEditCancel" listener="#{EventInstanceController.onCancelPrices}" update="@this" />
<p:column headerText="Preiskategorie">
<h:outputText value="#{priceCategoryTicketType.priceCategory.name}" />
</p:column>
<c:forEach items="#{EventInstanceController.ticketTypes}" var="item">
<p:column headerText="#{item.name}">
<p:cellEditor>
<f:facet name="output">
<h:outputText value="#{priceCategoryTicketType.ticketTypes[item]}" />
</f:facet>
<f:facet name="input">
<p:inputText converter="bigDecimalConverter" value="#{priceCategoryTicketType.ticketTypes[item]}" style="width:50%" />
</f:facet>
</p:cellEditor>
</p:column>
</c:forEach>
<p:column style="width:3%">
<p:rowEditor />
</p:column>
</p:dataTable>
EventInstanceController.onEditPrices
public void onEditPrices(RowEditEvent event) {
PriceCategoryTicketType pctt = (PriceCategoryTicketType)event.getObject();
System.out.println(pctt.getPriceCategory().getName());
for(int i = 0; i < priceCategoryTicketTypes.size(); i++) {
PriceCategoryTicketType pctickettype = priceCategoryTicketTypes.get(i);
if(pctt.getPriceCategory().equals(pctickettype.getPriceCategory())) {
for(Map.Entry<TicketType, BigDecimal> entry : pctt.getTicketTypes().entrySet()) {
System.out.println("TicketType: " + entry.getKey().getName());
System.out.println("Price: " + entry.getValue());
}
priceCategoryTicketTypes.set(i, pctt);
}
}
}
看起来像这样:
如您所见,每个单元格的默认值为0。 如果我将值(如图中所示)更改为f.e. 30 25 20并点击保存行图标,值将变回0 0 0。
onEditPrices中的System.out.println结果如下:
INFO: TicketType: Standard
INFO: Price: 0
INFO: TicketType: AHV
INFO: Price: 0
INFO: TicketType: Student
INFO: Price: 0
我错过了什么吗? :(
信息:我正在使用primefaces 4.0版(快照),但也尝试使用稳定版本3.5失败
提前致谢, Xera
答案 0 :(得分:0)
检查您的实体,也许某些验证没有在数据库中考虑或验证,我解决了在实体的列中放置nullable = true并在相应表的某些字段中允许空值的问题。 如果您的数据存在冲突,则某些限制无效。