Ajax呈现的jsf页面不';t绑定bean值

Ajax呈现的jsf页面不';t绑定bean值,ajax,jsf,jsf-2.2,Ajax,Jsf,Jsf 2.2,我有一个xhtml页面,其中包含一个通过ajax更新的bean值 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xmlns:h="http://java.sun.com/jsf/htm

我有一个xhtml页面,其中包含一个通过ajax更新的bean值

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
   "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"
    xmlns:h="http://java.sun.com/jsf/html"
    xmlns:f="http://java.sun.com/jsf/core"
    xmlns:p="http://primefaces.org/ui"
    xmlns:ui="http://java.sun.com/jsf/facelets">
<h:body>
    <div class="ui-fluid">
        <p:messages id="messages" showDetail="false" closable="true" />
        <h:form id="form">
            <p:panel id="panelInfo" header="Dados Local Instalação">
                <h:outputLabel for="tipoFornecimento" value="Tipo de Fornecimento"/>
                <p:selectOneMenu id="tipoFornecimento" value="#{cadastroController.localInstalacao.tipoFornecimento}">
                    <f:selectItems value="#{cadastroController.tiposFornecimento}"/>
                </p:selectOneMenu>
                <h:outputLabel for="familiaEquipamento" value="Família"/>
                <p:selectOneMenu id="familiaEquipamento" value="#{cadastroController.familia}" required="true">
                    <f:selectItem itemLabel="Selecione"/>
                    <f:selectItems value="#{cadastroController.familias}"/>
                    <f:ajax listener="#{cadastroController.setarEquipamentoPelaFamilia}" render=":form:panelEquipamento"/>
                </p:selectOneMenu>
            </p:panel>
            <p:panel id="panelEndereco" header="Endereço">
                <ui:include src="/logradouro.xhtml"/>
            </p:panel>
            <p:panel id="equipamentoNa" header="Equipamento NA">
                <ui:include src="/equipamentoNa.xhtml"/>
            </p:panel>
            <p:panel id="panelEquipamento" header="Equipamento">
                <ui:include src="#{cadastroController.panelEquipamento}"/>
            </p:panel>
            <p:commandButton value="Salvar" actionListener="#{cadastroController.salvarLocalInstalacao}" ajax="false"/>
        </h:form>
    </div>
</h:body>
</html>
也就是说,我选择了familia'AL',因此它将equipmento设置为new Alimentador(),并返回页面'Alimentador.xhtml'

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<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:p="http://primefaces.org/ui"
    xmlns:ui="http://java.sun.com/jsf/facelets">
        <p:outputLabel for="fasesEquipamento" value="Qtd Fases: " />
        <p:selectOneMenu id="fasesEquipamento" value="#{cadastroController.localInstalacao.equipamento.fases}">
            <f:selectItems value="#{cadastroController.fases}"/>
        </p:selectOneMenu>
        <p:outputLabel for="nrAlimentador" value="Número Alimentador: " />
        <p:inputMask mask="9?9" id="nrAlimentador" value="#{cadastroController.localInstalacao.equipamento.nrAlimentador}"/>
        <p:outputLabel for="nrEquipamento" value="Número Equipamento: " />
        <p:inputMask mask="9?9999" id="nrEquipamento" value="#{cadastroController.localInstalacao.equipamento.nrEquipamento}"/>
        <p:outputLabel for="nrEquipamentoAnterior" value="Número Equipamento Anterior: " />
        <p:inputMask mask="9?9999" id="nrEquipamentoAnterior" value="#{cadastroController.localInstalacao.equipamento.nrEquipamentoAnterior}"/>
        <p:outputLabel for="nrSubestacao" value="Número Subestação: " />
        <p:inputMask mask="9?99" id="nrSubestacao" value="#{cadastroController.localInstalacao.equipamento.nrSubestacao}"/>
        <p:outputLabel for="potencia" value="Potencia: " />
        <p:inputMask mask="9?99.9" id="potencia" value="#{cadastroController.localInstalacao.equipamento.potencia}"/>
        <p:outputLabel for="regionalEquipamento" value="Regional: " />
        <p:selectOneMenu id="regionalEquipamento" value="#{cadastroController.localInstalacao.equipamento.regional}">
            <f:selectItems value="#{cadastroController.regionais}"/>
        </p:selectOneMenu>
</ui:composition>

我使用的是ViewScope ManagedBean,但在提交表单后,通过ajax在“alimentador.xhtml”中添加的值不会绑定到bean localInstalacao


有什么想法吗?

没关系,我通过升级到Mojarra 2.2解决了这个问题 这似乎是上面描述的一个已知错误


要将JBOSS中的Mojarra版本升级为7.1,请执行以下步骤

没关系。我通过升级到mojarra 2.2来修复它。这似乎是在的[link]副本上描述的一个bug
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<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:p="http://primefaces.org/ui"
    xmlns:ui="http://java.sun.com/jsf/facelets">
        <p:outputLabel for="fasesEquipamento" value="Qtd Fases: " />
        <p:selectOneMenu id="fasesEquipamento" value="#{cadastroController.localInstalacao.equipamento.fases}">
            <f:selectItems value="#{cadastroController.fases}"/>
        </p:selectOneMenu>
        <p:outputLabel for="nrAlimentador" value="Número Alimentador: " />
        <p:inputMask mask="9?9" id="nrAlimentador" value="#{cadastroController.localInstalacao.equipamento.nrAlimentador}"/>
        <p:outputLabel for="nrEquipamento" value="Número Equipamento: " />
        <p:inputMask mask="9?9999" id="nrEquipamento" value="#{cadastroController.localInstalacao.equipamento.nrEquipamento}"/>
        <p:outputLabel for="nrEquipamentoAnterior" value="Número Equipamento Anterior: " />
        <p:inputMask mask="9?9999" id="nrEquipamentoAnterior" value="#{cadastroController.localInstalacao.equipamento.nrEquipamentoAnterior}"/>
        <p:outputLabel for="nrSubestacao" value="Número Subestação: " />
        <p:inputMask mask="9?99" id="nrSubestacao" value="#{cadastroController.localInstalacao.equipamento.nrSubestacao}"/>
        <p:outputLabel for="potencia" value="Potencia: " />
        <p:inputMask mask="9?99.9" id="potencia" value="#{cadastroController.localInstalacao.equipamento.potencia}"/>
        <p:outputLabel for="regionalEquipamento" value="Regional: " />
        <p:selectOneMenu id="regionalEquipamento" value="#{cadastroController.localInstalacao.equipamento.regional}">
            <f:selectItems value="#{cadastroController.regionais}"/>
        </p:selectOneMenu>
</ui:composition>