0

我有几个 JSF 页面有一个 PrimeFaces 对话框来创建一个Person. 因为此对话框包含文件上传,所以我不想使用 AJAX。对话框将在创建时关闭Person。如果Person未创建(验证失败或其他),则应显示对话框。

我见过人们使用visible="#{not empty facesContext.messages}",但是我不能使用它,因为被调用的方法FacesMessage在任何情况下都会返回 a 。

我现在的想法是生成一个视图参数(例如 showDialog)并使用visible="#{param.showDialog}".

我尝试过使用导航案例,但由于该方法是从多个页面调用的,因此我无法制作仅添加视图参数的通用导航案例。这将是一个想法:

<navigation-rule>
    <from-view-id>*</from-view-id>
    <navigation-case>
        <from-action>#{personBean.create}</from-action>
        <from-outcome>true</from-outcome>
        <to-view-id>#{from-view-id}</to-view-id>
        <redirect>
            <view-param>
                <name>showDialog</name>
                <value>#{form-outcome}</value>
            </view-param>
        </redirect>
    </navigation-case>
</navigation-rule>

使用导航案例的另一个问题是对话框是一个复合标记,并且使用属性提供操作。当我确实使用上述导航箱时,我收到一条消息说Unable to find matching navigation case with from-view-id '/test.xhtml' for action '#{cc.attrs.saveAction}' with outcome 'true'

我认为最好/最简单的解决方案是在方法中添加视图参数。但是,requestmap 是不可变的,并且返回包含的 String?showDialog=true也不起作用。

4

2 回答 2

0

我不会用导航规则来处理它,而是让它类似于Primefaces Showcases 的登录示例。如您所见,当验证失败时对话框保持打开状态,如果提交操作成功则关闭。

于 2012-09-08T22:39:27.520 回答
0

我找到了一个没有视图参数想法的解决方案。

要提交表单,我使用p:commandButton此按钮使用 AJAX。此按钮仅设置字段、验证字段并更新输入字段的容器。幸运的是,PrimeFaces 返回一个 JavaScript 值 ( args.validationFailed),指示验证是否失败。

当我单击保存按钮时,字段会通过 AJAX 进行验证,从而使对话框保持打开状态。当验证通过时,我点击使用 JavaScript 的非 AJAX 链接。

JSF:

<p:commandButton value="Save" update="containerOfValues"
    oncomplete="afterValidation(xhr, status, args)" />
<p:commandLink ajax="false" action="#{cc.attrs.saveAction}"
    style="display:none" binding="#{saveLink}" />

JavaScript:

function afterValidation(xhr, status, args)
{
    if (!args.validationFailed)
    {
        $("[id='#{saveLink.clientId}']").click();
    }
}
于 2012-09-09T12:55:43.107 回答