JSF 2.0中的AJAX onSubmit验证

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JSF 2.0中的AJAX onSubmit验证相关的知识,希望对你有一定的参考价值。

我开始学习JSF2.0,并遇到了一个问题。有关如何进行的任何建议都将受到欢迎。

为简单起见,我重命名了表单元素和类。

我有一个表格,例如:

<h:form id="frmSearch">
    <h:inputText id="dataPoint1" value="#{bean.dataPoint1}"/>
    <div id="dataPoint1Error" class="msgError">Value not found in database.</div>

    <h:inputText id="dataPoint2" value="#{bean.dataPoint2}"/>
    <div id="dataPoint2Error" class="msgError">Value not found in database.</div>

    <h:commandButton action="#{bean.validate}" type="submit" value="Search"/>
</h:form>

CSS类“msgError”默认隐藏元素。

我想在“bean”类中基本上有一个方法,通过检查数据库来验证输入,然后如果找不到该值,取消隐藏错误消息,或者如果找到它,则执行另一个执行的方法实际的功能。

在我看来,它在Java中的工作方式有点类似(原谅任何语法错误,只需按照我的想法输入):

@ManagedBean
public class Bean {
    private String dataPoint1 = "";
    private String dataPoint2 = "";

    public boolean validate() {
        if(dao.fieldExists(this.dataPoint1) && dao.fieldExists(this.dataPoint2)) { //check the database
            performFunctionality();
            return true;
        }
        else {
            return false; //and show error div on screen
        }
    }        

    public void performFunctionality() {
        //do whatever
    }

    //getters and setters
}

任何建议都会非常欢迎!谢谢!

答案

您没有使用JSF内置验证工具。利用它。

这是它的样子:

<h:form id="frmSearch">
    <h:inputText id="dataPoint1" value="#{bean.dataPoint1}" validator="#{bean.validateDataPoint}" />
    <h:message for="dataPoint1" />

    <h:inputText id="dataPoint2" value="#{bean.dataPoint2}" validator="#{bean.validateDataPoint}" />
    <h:message for="dataPoint2" />

    <h:commandButton action="#{bean.performFunctionality}" value="Search">
        <f:ajax execute="@form" render="@form" />
    </h:commandButton>
</h:form>

public void validateDataPoint(FacesContext context, UIComponent component, Object convertedValue) {
    if (!dao.fieldExists((String) convertedValue)) {
        throw new ValidatorException(new FacesMessage("Value not found in database."));
    }
}        

必须通过命令按钮的动作方法执行performFunctionality()

当验证失败(即抛出ValidatorException)时,该消息将显示在与输入组件关联的<h:message>中,并且不会调用action方法。 validator属性也可以指向一个实现javax.faces.validator.Validator的值得一提的类。添加了<f:ajax>以使其成为ajax提交。

See also:

无论您何时学习JSF,请确保您还阅读了有关转换和验证的章节。不要过多考虑php / ASP / JSP / jQuery的方式。 JSF是一个基于MVC框架的完整组件。

以上是关于JSF 2.0中的AJAX onSubmit验证的主要内容,如果未能解决你的问题,请参考以下文章

JSF 2.0 验证码如何工作

JSF 2.0 AJAX:使用 jsf.ajax.request(或其他方式)从 javascript 调用 bean 方法

JSF 2.0:按 ENTER 时的 ajax 请求

JSF 2.0 复合组件 - ajax 渲染参数 OUTSIDE 组件定义

JSF 2.0 有比 Icefaces 更好的 Ajax Push

JSF 2.0 每页生成多个请求