Java 如何在Adf中撤消编辑后保留当前行的值?
我有一个弹出表单,可以在adf表中插入数据, 我可以按“添加”按钮插入行, 我可以编辑插入的行。 这是代码: 添加按钮:Java 如何在Adf中撤消编辑后保留当前行的值?,java,oracle-adf,Java,Oracle Adf,我有一个弹出表单,可以在adf表中插入数据, 我可以按“添加”按钮插入行, 我可以编辑插入的行。 这是代码: 添加按钮: JSFUtils.setExpressionValue("#{pageFlowScope.status}", "add"); RichPopup.PopupHints hints = new RichPopup.PopupHints(); ResetUtils.reset(getmyPopup()); getmyPopup().show(hints); Operat
JSFUtils.setExpressionValue("#{pageFlowScope.status}", "add");
RichPopup.PopupHints hints = new RichPopup.PopupHints();
ResetUtils.reset(getmyPopup());
getmyPopup().show(hints);
OperationBinding createOp = ADFUtils.findOperation("CreateInsert");
createOp.execute();
“添加”弹出窗口有两个按钮“确定”和“取消”:
“确定”按钮:
getmyPopup().hide();
问题是,当我在编辑模式下打开弹出窗口,更改LOV值,然后按下取消按钮时,弹出窗口中有一些LOV清除了一些输入文本
我试图恢复旧的行:并且
这是编辑按钮的代码:
rowimpl currentRow = (rowimpl )ADFUtils.findIterator("iterator").getCurrentRow();
rowimpl backupRow=(rowimpl )ADFUtils.findIterator("iterator").getCurrentRow();
JSFUtils.setExpressionValue("#{pageFlowScope.value1}",currentRow.getValue1();
.
.
. // for all values
这是取消按钮代码:
DCIteratorBinding dciter = ADFUtils.findIterator("itertaor");
dciter.getRowSetIterator().setCurrentRow(backupRow);
问题是备份行未正确设置为旧值听起来您希望在用户取消编辑操作时执行部分回滚。为此,您可以为特定的VO编写一些方法,将它们公开为客户机接口,并将它们绑定到Cancel按钮。我记得最简单的方法是: 在VO中创建与EO链接的瞬态属性,该属性将指示当前行状态。将其设为整数,并将其命名为RowStatus或任何您喜欢的名称 在VO的ViewObjectRowImpl类中,找到上面创建的瞬态属性的getter方法,并将其替换为:
public Integer getRowStatus() {
/*
2-Modified
0-New
1-Unmodified
-1-Initialized
*/
byte entityState = this.getEntity(0).getEntityState();
return new Integer(entityState);
}
在ViewObjectImpl中创建一个方法,该方法将还原一行:
public void revertChangesCurrentRow(Row row) {
if (row!= null) {
row.refresh(Row.REFRESH_UNDO_CHANGES | Row.REFRESH_WITH_DB_FORGET_CHANGES);
}
}
在ViewObjectImpl中创建另一个方法,该方法将根据每一行状态(从transient属性获得)删除新行或撤消更改,从而仅回滚此VO:
最后,在VO的客户端界面中公开方法revertOrRemoveRowValues,然后将其作为按钮拖放到页面上。这将把您上面写的函数绑定到按钮上,每次单击它时,它都会执行部分回滚,只在该VO上执行回滚。它通过删除已添加的新行或撤消对现有行的编辑来实现这一点,并且它还将使用DB中的值刷新VO(由于使用了this.executeQuery()命令,因此用户应该看到任何编辑之前的VO)
public void revertOrRemoveRowValues() {
ViewObject myVo = this;
RowSetIterator myVoIterator = myVo.createRowSetIterator(null);
while (myVoIterator.hasNext()) {
Row nextRow = myVoIterator.next();
if (nextRow.getAttribute("RowStatus") != null) {
Integer rowStatus = (Integer) nextRow.getAttribute("RowStatus");
if (rowStatus == 2) {
//modified rows
revertChangesCurrentRow(nextRow);
} else if (rowStatus == 0) {
//new row (added by create)
nextRow.remove();
}
}
}
this.executeQuery();
}