3

我无法在 tabView 中使用 ui:include。我正在尝试使用包含的 Facelet 制作动态选项卡。

这是我的代码:

<p:tabView id="panelGl" var="tabContent" value="#{mainPageBackingBean.tabs}" widgetVar="panelGlJs" style="height: 100%;" dynamic="true" >
            <p:ajax event="tabClose" listener="#{mainPageController.onTabClose}" oncomplete="questionDialogWV.show()" update="@(this) :questionForm:questionFormPanel" />
            <p:ajax event="tabChange" onstart="setActive()" update="@(this)" />         
            <p:tab title="#{tabContent.title}" titletip="#{tabContent.description}" closable="true">
                <ui:include src="#{mainPageBackingBean.tabContents}" />
            </p:tab>
</p:tabView>

#{mainPageBackingBean.tabContents}运行时值指向这个 Facelet :

<?xml version="1.0" encoding="UTF-8"?>
<ui:composition xmlns="http://www.w3.org/1999/xhtml"
 xmlns:ui="http://java.sun.com/jsf/facelets"
 xmlns:f="http://java.sun.com/jsf/core"
 xmlns:h="http://java.sun.com/jsf/html"
 xmlns:fn="http://java.sun.com/jsp/jstl/functions"
 xmlns:p="http://primefaces.org/ui">
 <p:panel>
    <h:form> 
        <p:commandButton id="testEmail" value="" process="@this" actionListener="#{communicationChannelsController.testEmailChannel()}"/>
    </h:form>
 </p:panel>
</ui:composition>

ui:include当我在外部使用上述内容时,p:tabView它可以正常工作(我可以communicationChannelsController.testEmailChannel()毫无问题地调用)。此外,当我将上述文件的内容复制到里面时,p:tab一切正常。

问题是,当组合p:tab并且ui:include不起作用时,不会调用此 bean 方法。

mainPageBackingBean在我的示例中使用一些导航 bean 创建动态选项卡的最佳方法是什么?

4

0 回答 0