gpt4 book ai didi

validation - Primefaces tabView 在选项卡更改时执行表单验证

转载 作者:行者123 更新时间:2023-12-02 09:09:05 27 4
gpt4 key购买 nike

我的 p:tabView 组件遇到严重问题。我已将 dynamic="true"cache="false" 设置为 tabView。其中一个选项卡具有一些设置为 required="true" 的输入组件。

现在,当我每次更改选项卡时,都会进行表单验证,并且 FacesMessages 会以咆哮的形式显示。

这是选项卡:

<ui:composition xmlns="http://www.w3.org/1999/xhtml"
xmlns:ui="http://java.sun.com/jsf/facelets"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:f="http://java.sun.com/jsf/core"
xmlns:p="http://primefaces.org/ui"
template="/WEB-INF/templates/globalTemplate.xhtml">

<ui:define name="title">#{adbBundle['home']}</ui:define>
<ui:define name="content">
<p:growl id="growl" showDetail="true" autoUpdate="true" />

<p:tabView id="adminTabView" dynamic="true" cache="false">
<p:tab title="#{adbBundle['admin.customerTab.title']}"
id="customerTab">
<ui:include src="/WEB-INF/includes/adminCustomer.xhtml" />
</p:tab>
<p:tab title="#{adbBundle['admin.activityTab.title']}"
id="activityTab">
<ui:include src="/WEB-INF/includes/addActivity.xhtml" />
</p:tab>
</p:tabView>

</ui:define>

</ui:composition>

adminCustomer.xhtml 包含表单,它是:

<ui:composition xmlns="http://www.w3.org/1999/xhtml"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:f="http://java.sun.com/jsf/core"
xmlns:ui="http://java.sun.com/jsf/facelets"
xmlns:p="http://primefaces.org/ui">

<h:form id="customerForm">
<p:panel id="addCustomerPanel" toggleable="true"
header="#{adbBundle['admin.addCustomerPanel.header.new']}">
<p:panelGrid columns="2" id="addCustomerTable"
styleClass="addCustomerTable">
<f:facet name="header">
<p:outputLabel id="header"
value="#{adbBundle['admin.addCustomerPanel.addCustomerTable.header']}" />
</f:facet>

<p:outputLabel for="customerName"
value="#{adbBundle['admin.addCustomerPanel.addCustomerTable.customerName']}" />
<h:panelGroup layout="block">
<p:inputText id="customerName" styleClass="customerName"
autocomplete="off"
label="#{adbBundle['admin.addCustomerPanel.addCustomerTable.customerName']}"
value="#{adminController.customerDTO.customerName}"
required="true" />
</h:panelGroup>

<p:outputLabel for="customerId"
value="#{adbBundle['admin.addCustomerPanel.addCustomerTable.customerId']}" />
<h:panelGroup layout="block">
<p:inputText id="customerId" autocomplete="off"
label="#{adbBundle['admin.addCustomerPanel.addCustomerTable.customerId']}"
value="#{adminController.customerDTO.customerId}" required="true">
<f:validator validatorId="customerIDValidator" />
</p:inputText>
</h:panelGroup>

<p:outputLabel for="activeStatus"
value="#{adbBundle['admin.addCustomerPanel.addCustomerTable.activeStatus']}" />
<h:panelGroup layout="block">
<p:selectBooleanCheckbox id="activeStatus"
value="#{adminController.customerDTO.active}" />
</h:panelGroup>

<f:facet name="footer">
<p:commandButton value="#{adbBundle['saveButton']}"
actionListener="#{adminController.saveCustomer}"
icon="ui-icon-check"
update=":growl, @form" />
</f:facet>
</p:panelGrid>
</p:panel>
</h:form>

</ui:composition>

我无法找到我做错了什么以及如何解决它。我正在使用 Primefaces 3.4.2 和 JSF Mojarra 2.1.7-jbossorg。任何指针都会对我非常有帮助。

我也在 PrimeFaces 论坛上问过这个问题。

最佳答案

这就是tabView 的工作原理。以下是 PrimeFaces 跟踪器的相关问题:

如您所见,第一个被标记为 WontFix。 第二个是重复的,但最后您会看到另一种解决方法

如果您仔细阅读该线程,您可能会注意到一些解决方法仍然存在。如果您被迫使用 tabView,请尝试其中之一。还可以考虑使用 PrimeFaces - Wizard如果您想在不同的选项卡中使用输入。

关于validation - Primefaces tabView 在选项卡更改时执行表单验证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14010537/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com