0

私はJSF、RichCalendar、a4jを使用しています。私の問題:自分のWebサイトのコンポーネントを再レンダリングしたいのですが、誰かが1つのリッチカレンダー入力フィールドの日付を「12.aa.2012」に編集すると、FacesMessageがスローされます。これは正しくて適切です。とにかく、私のa4j-rerender-eventは、handeledfacesMessagesが原因でトリガーされませんでした。私のTomcat-Consoleで、次のエラーメッセージが表示されます。

WARNUNG: There are some unhandled FacesMessages, this means not every FacesMessage had a chance to be rendered.
These unhandled FacesMessages are: 
- Bitte ein gültiges Datum eingeben!

この問題をどのように処理できますか?errorMessageを表示するいくつかの方法を試しましたが、それを表示する方法を理解できますが、警告があり、triggered-rerender-eventがまだありませんか?

前もって感謝します。

更新:これが私の質問のコードです。ラジオボタンの1つを選択するとわかるように、「admissionDateContainer」のように1つのdateContainerが表示されます。値を「asd」に変更し、別の選択肢を選択すると、関連するボックスの再レンダリングは行われず、選択肢は変更されますが、間違ったdateContainerがそこに残りますか?!

<h:panelGroup layout="block" id="caseTypeContainer" rendered="#{CaseController.isFallContainer}" styleClass="fieldContainer">
    <t:outputLabel for="caseType" styleClass="generalInputLabel" style="width:200px; float:left;" value="#{resources.labels['caseType']}:" title="#{resources.labels['caseType']}" />
    <h:selectOneRadio id="caseType" style="font-size:13px;" value="#{CaseController.caseType}" styleClass="radioButtonTableMasterdata inlineBlock">
    <f:selectItem itemValue="#{resources.labels['caseTypeDocAttrStationaer']}" itemLabel="#{resources.labels['caseTypeDocAttrStationaerLabel']}" />
    <f:selectItem itemValue="#{resources.labels['caseTypeDocAttrAmbulant']}" itemLabel="#{resources.labels['caseTypeDocAttrAmbulant']}"/>
    <f:selectItem itemValue="#{resources.labels['caseTypeDocAttrUnbekannt']}" itemLabel="#{resources.labels['caseTypeDocAttrUnbekannt']}"/>
    <a4j:support oncomplete="initializeFocusBlurEvents(); " event="onchange" reRender="captureDateContainerDiv, admissionDateContainerDiv, dischargeDateContainerDiv, messagesContainer, warnings"/>
    </h:selectOneRadio>
</h:panelGroup>
<t:div id="admissionDateContainerDiv">
    <h:panelGroup layout="block" id="admissionDateContainer" rendered="#{CaseController.isCaseTypeStationaerOrAmbulant}" styleClass="fieldContainer  showDateInputWithTime">
        <t:outputLabel for="admissionDate" rendered="#{CaseController.isCaseTypeStationaer}" styleClass="generalInputLabel" style="width:200px;" value="#{resources.labels['caseAdmissionDateStationaer']}:" title="#{resources.labels['caseAdmissionDateStationaer']}" />
    <t:outputLabel for="admissionDate" rendered="#{CaseController.isCaseTypeAmbulant}" styleClass="generalInputLabel" style="width:200px;" value="#{resources.labels['caseAdmissionDateAmbulant']}:" title="#{resources.labels['caseAdmissionDateAmbulant']}" />
    <rich:calendar id="admissionDate" value="#{CaseController.caseContainerAdmissionDate}" datePattern="dd.MM.yyyy HH:mm" enableManualInput="true" direction="auto">
        <f:facet name="footer">
        <h:panelGrid columns="3" width="100%" columnClasses="fake, width100 talign">
        <h:outputText value="{selectedDateControl}" style="font-weight:bold;" />
    <h:outputText value="{timeControl}" style="font-weight:bold;" />
    <h:outputText value="{todayControl}" style="font-weight:bold;" />
        </h:panelGrid>
    </f:facet>
    </rich:calendar>
    <rich:message for="admissionDate"  />
</h:panelGroup>
</t:div>
<t:div id="messagesContainer" rendered="true"> 
    <p>Messages global</p>
<rich:messages global="true" />
</t:div>
4

1 に答える 1

3

<rich:messagesまたは<rich:messageをページに追加

rich:messagesrich:messageを見てください

またrendered、あなたがクリックされた後に彼らがいることを確認してください...あなたのカレンダーbuttonのに彼らのIDまたは彼らのラッパー(@form例えば)IDを追加してくださいreRender

于 2012-06-19T11:41:23.567 に答える