如何使autoSubmit的控件也能触发Uncommitted Data Warning?

Adf提供了一个相当有用的功能,就是当页面上有数据发生变化之后,当用户试图离开此页面的时候,会弹出"Uncommitted Data Warning"的消息,让用户确认是否真的要离开该页面。

但是,当页面上存在编辑控件的autoSubmit属性设置为true的时候,改变这个控件的值,然后试图离开该页面时,不会弹出消息确认。

原因是当autoSubmit属性设置为true时,当该控件的值发生改变后,就会以异步的方式自动把新值提交到服务器端(依次经过JSF默认的生命周期的六个阶段),
当这个异步请求完成之后,那么该控件客户端的值就不在保留了,而服务器端的值也被更新了,因此,该控件也就不再是Dirty的了。

所以这个时候,当你在点击浏览器上的后退按钮,离开该页面的时候,也不会提示"Uncommitted Data Warning"的消息了。

所以需要如下的JS代码:

 

markDirty = function(dirtyFieldId) {
    return function(evt) {
        var txtDirty = AdfPage.PAGE.findComponentByAbsoluteId(dirtyFieldId);
        if (txtDirty != null) {
                txtDirty.setValue("dirty");
        }
    }
}

然后在autoSubmit的空间中插入如下的client listener.

 

<af:clientListener type="valueChange" method="markDirty('txtLocalDirtyFlg')"/>

详细参见:https://forums.oracle.com/forums/thread.jspa?threadID=2125354&tstart=0

 

上述方法对没有任何绑定的页面有效(所有的数据源都是通过manage bean获取,而不是绑定AM data control的方式),对于使用绑定AM data control方式的页面,有时候需要加入下面的代码到Cancel按钮的标签中(可能的原因是绑定的data Control是作为Reference,而不是需要更新的Data Control,比如说,只是进行条件过滤的下拉列表):

 

checkUncommittedData = function(dirtyFieldId) {
    return function(evt) {
        var txtDirty = AdfPage.PAGE.findComponentByAbsoluteId(dirtyFieldId);
        AdfPage.PAGE.setDataDirty(txtDirty.getValue() != null && txtDirty.getValue() != "");
    }
}

 

<af:clientListener method="checkUncommittedData('pt1:txtLocalDirtyFlg')" type="click"/>

你可能感兴趣的:(submit)