0

我想问一下为什么primefaces的部分渲染不起作用。POST 请求一直在发送,但不会重新呈现。

<?xml version='1.0' encoding='UTF-8' ?>
<!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:p="http://primefaces.org/ui">
    <h:head>
        <title>Facelet Title</title>
    </h:head>
    <h:body>
        <p:messages />
        <h:form>
            <table style="width: 100%">
                <tr>
                    <td><p:outputLabel for="inp1" value="S1" /></td>
                    <td>
                        <p:inputText id="inp1" value="#{form.e.s1}">
                            <p:ajax process="inp1" update="msg1"
                                    event="keyup" />
                        </p:inputText>
                        <p:watermark for="inp1" value="Wpisz S1" />
                        <p:message for="inp1" id="msg1" />
                    </td>
                </tr>
                <tr>

                    <td>Toolbox</td>
                    <td>
                        <p:selectBooleanCheckbox id="inpToolbox" value="#{form.toolbox}">
                            <p:ajax process="inpToolbox" update="toolboxOptions" />
                        </p:selectBooleanCheckbox><br />
                        <p:panel id="toolboxOptions" rendered="#{form.toolbox}">
                            Name: <p:inputText value="#{form.toolboxDescription}" /><br />
                            Number: <p:inputText value="#{form.toolboxNr}" /><br />
                        </p:panel>
                    </td>

                </tr>
            </table>

            <p:commandButton action="#{form.save}" ajax="false"
                             value="Save" />

        </h:form>
    </h:body>
</html>

我不知道,为什么它不应该工作。我希望每次更改工具箱值以显示有关工具箱的附加信息表单

4

1 回答 1

2

当您想更新视图的某些部分时,您必须指定实际存在于 DOM 中的元素的 id。但是您尝试更新的面板并不总是存在于 DOM 中,只有在 form.toolbox 评估为 true 的情况下。所以当它为假时,它不能被更新,所以它不会被添加到视图中。解决此问题的方法是将面板包装在另一个元素中并更新该元素。这将起作用,因为 wrapper-element 始终存在。

因此,请尝试以下面板部分:

<h:panelGroup id="toolboxOptions">
    <p:panel id="toolboxOptionsPanel" rendered="#{form.toolbox}">
    ....
    </p:panel>
</h:panelGroup>

查看以下问题的答案以获得进一步解释: JSF + PrimeFaces: `update` attribute does not update component

于 2013-08-24T20:45:51.937 回答