我有两个 PrimeFacesp:calendar
组件,一个代表开始日期,另一个代表结束日期。
每当其中一个发生更改时,我现在都想运行一个验证器方法。
这是结束日期部分:
<p:calendar id="end-date"
widgetVar="testEndDate"
value="#{testManager.endDate}"
mindate="#{testManager.minEndDate}"
maxdate="#{testManager.maxEndDate}"
validator="#{testManager.validateEndDate}">
<p:ajax event="dateSelect" update="begin-date msgs" global="false" />
</p:calendar>
这是验证器方法代码:
@Override
public void validateEndDate(FacesContext context, UIComponent component, Object value)throws ValidatorException
{
System.out.println(this.getClass().getSimpleName() + ".validateEndDate()!");
Date beginDate = this.getBeginDate();
Date endDate = (Date)value;
if ( endDate != null && endDate.getTime() <= beginDate.getTime() )
{
System.out.println("End date less than or equal to begin date!");
// this.setValidated( false );
//
// throw new ValidatorException( JsfUtil.getValidationErrorFacesMessage( "common.validator.validTo.message" ) );
context.addMessage(null, JsfUtil.getValidationErrorFacesMessage("common.validator.validTo.message"));
}
List < FacesMessage > messages = context.getMessageList();
if ( !messages.isEmpty() )
{
System.out.println("Faces messages list not empty! Size = " + messages.size());
this.setValidated(false);
throw new ValidatorException(messages);
}
this.setValidated(true);
}
这就是我所做的:
- 通过命令按钮显示对话框。
- 点击进入空的结束日期日历输入,弹出日历。
- 单击 22(与开始日期相同的日期)。
该代码基本上可以工作,至少根据控制台输出:
INFO: DefaultValidatingBeginEndDateChecker.validateEndDate()!
INFO: End date less than or equal to begin date!
INFO: Faces messages list not empty! Size = 1
但是,这在 UI 上显示了FacesMessage
两次相同的内容:
如您所见,输出与验证器方法所说的不匹配。
有谁知道发生了什么/错误以及如何解决这个问题?(还要注意显示工作解决方案的注释代码,但我需要知道为什么这不起作用,因为我有另一个更复杂的验证器,它有 1+ ifs 应该显示多个消息......)。