如何停止弹出消息确认验证是否失败

时间:2014-04-19 11:52:14

标签: javascript jquery jsf jsf-2 primefaces

我有一个确认消息框,当有人点击保存按钮时会出现,只是简单地要求他们确认他们要保存,但是即使所有验证都失败也会弹出,是否有办法如果所有验证都成功,则显示消息框

<p>
        <p:commandButton value="#{bundle.buttonSaveMark}"  icon ="ui-icon-disk" update="displayMark :growl" oncomplete="PF('dlg').show()" /> 
    </p>
    <p:dialog header="Confirm Mark" widgetVar="dlg" showEffect="fold" hideEffect="fold">  
        <h:panelGrid id="displayMark" columns="2" cellpadding="5">  
            <h:outputText value="Mark to be submitted: " />  
            <h:outputText value="#{selectedValue}"/>  
            <p:commandButton id="save"
                             value="#{bundle.buttonSave}"
                             actionListener ="#{markingBean.editMark}"
                             update="Navigation :growl"
                             icon="ui-icon-disk"
                             oncomplete="PF('nav').show()"/>
        </h:panelGrid>  
    </p:dialog>  

    <p:dialog header="Navigation" widgetVar="nav" showEffect="fold" hideEffect="fold">  
        <h:panelGrid id="Navigation" columns="2" cellpadding="5">  
            <h:outputText value="Return to this project's marking page: " />  
            <p:button id="go"
                      value="#{bundle.buttonProjMark}"
                      outcome ="/lecturer/marking/marking-index.xhtml?edit_id=#{markingBean.markToEdit.id}"
                      icon="ui-icon-clipboard"/>
            <h:outputText value="Return to staff homepage: " />  
            <p:button id="staffHome"
                      value="#{bundle.buttonStaffHome}"
                      outcome ="/index"
                      icon="ui-icon-home"/>
        </h:panelGrid>  
    </p:dialog>   

这是按钮,然后是确认

1 个答案:

答案 0 :(得分:1)

您可以使用

从Java代码更新导航对话框
RequestContext.getCurrentInstance().update("Navigation");

还要从java代码中添加一个callBackParam:

RequestContext.getCurrentInstance().addCallbackParam("showDialog",true);

将以上代码添加到您的markingBean.editMark操作中。如果验证失败,您的操作将无法被调用,因此不会添加callbackParam,这样对话框就不会出现。

在客户端应创建一个处理请求完成的js函数:

function handle(args) {
    if (data != null && data.showDialog) {
        PF('nav').show()
    }
}

在按钮上:

oncomplete="handle(args);"