0

我在使用 PrimeFaces 3.4 和 Facelets 时遇到问题我创建了一个 Facelets 模板,其中包含以下内容:

<?xml version='1.0' encoding='UTF-8' ?> 

<h:head>
    <h:outputStylesheet library="css" name="styles.css"></h:outputStylesheet>
</h:head>

<h:body>
    <p:layout fullPage="true">
        <p:layoutUnit position="north" size="200px" collapsible="true">
            <ui:include src="header.xhtml"></ui:include>
        </p:layoutUnit>
        <p:layoutUnit position="south" size="50px" collapsible="true">
            Sul
        </p:layoutUnit>
        <p:layoutUnit id="contentView" position="center">
            <ui:insert name="content"></ui:insert>
        </p:layoutUnit>        
    </p:layout>
</h:body>

我的 index.xhtml:

    <?xml version='1.0' encoding='UTF-8' ?>
<!DOCTYPE composition PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<ui:composition template="./maintemplate.xhtml"
                xmlns:h="http://java.sun.com/jsf/html"
                xmlns:p="http://primefaces.org/ui"
                xmlns:ui="http://java.sun.com/jsf/facelets">
    <ui:define id="contentView" name="content">
        <ui:include src="#{userController.currentPage}"></ui:include>
    </ui:define>
</ui:composition>

因此,userController.currentPage 一开始就包含一个使用 primeFaces 组件的登录页面。当我单击 header.xhtml 中可用的菜单时,我有以下内容:

<p:menuitem value="Tickets" actionListener="#{userController.setCurrentPage('tickets.xhtml')}" update=":contentView" ajax="false"></p:menuitem>

单击中心布局后变为空白。我没有看到任何错误或有问题的信息。我可以毫无问题地渲染页面tickets.xhtml。

非常感谢任何帮助。

我正在使用 Netbeans 7.3 RC1 - Apache Tomcat 7.0.34.0 / PrimaFaces 3.4 / JSF 2.1

编辑:将 ajax="false" 放在菜单中有效,但它刷新了所有页面。知道如何在不刷新整个页面的情况下完成这项工作,我只想刷新中心页面。

4

1 回答 1

0

终于设法做到了。在这里找到以下内容:

如何通过导航菜单 ajax-refresh 动态包含内容?(JSF SPA)

基于上述答案,我执行了以下操作: 1.将 ajax 标签和菜单放入其中。2. 这也是我的错误,将 ajax 渲染从 更改<ui:layoutUnit><h:form> 3. 从子 xhtml 中删除所有 h:form 标签,因为它现在包含在模板文件中。

在此之后,它可以正常工作。

于 2013-02-09T12:27:55.130 回答