我无法在 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 创建动态选项卡的最佳方法是什么?