gpt4 book ai didi

jsf - 如何在 PrimeFaces 5.0 中使用 tabView 获取动态选项卡名称和数据?

转载 作者:行者123 更新时间:2023-12-04 22:35:41 25 4
gpt4 key购买 nike

我需要动态显示选项卡名称。每个选项卡都会有自己的数据列表。例如如果选项卡名称是“Student”,当用户点击“Student”选项卡时,它会显示一个学生列表。如果单击“教师”选项卡,将显示教师列表。我使用以下链接引用 PrimeFaces 示例。 http://www.primefaces.org/showcase/ui/panel/tabView.xhtml

我尝试使用数据模型和 Ajax 事件示例,但无法显示所需数据。事件不适用于数据模型。

我试过以下方法,

<p:tabView value="#{myBean.tabList}" var="tabItem">
<p:tab title="#{tabItem.tabTitle}">
<h:outputText value="#{tabItem.valueA}"/>

</p:tab>
</p:tabView>

如果我使用这种方法,数据是动态的,但不是我想要的方式。我的数据就像标签名称是一个列表,每个标签的数据是另一个列表。

TabView tabView = new TabView();
Tab newTab = new Tab();
newTab.setTitle("Tab Title");

Tab newTab2 = new Tab();
newTab2.setTitle("Tab Title2");
tabView.getChildren().add(newTab2);

有人能帮忙吗?

更新

我现在能够通过从支持 bean 创建 PrimeFaces 代码来根据需要显示动态数据。 TabView 在 <p:dialog> 里面盒子。

out1 = new SelectBooleanCheckbox();
out1.setValue(obj.isTabViewCheckBox());
out2 = new HtmlOutputLabel();
out2.setValue(obj.getTaskName());

我面临新问题.. 提交后我无法获取 SelectBooleanCheckbox 值。XHTML代码:

<p:dialog header="#{BB.projNo}" widgetVar="addData" modal="true" showEffect="explode" hideEffect="explode" styleClass="editProjects">
<h:panelGrid id="TaskAdd">
<f:facet name="header">
<h:outputText value="Tasks"/>
</f:facet>
<p:tabView id="tabView" binding="#{BB.tabView}">
</p:tabView>
</h:panelGrid>
<p:commandButton id="saveBtn" action="#{BB.addTask}" value="Save" style="align:center;" styleClass="buttonStyle" onstart="showLoadImg();" oncomplete="hideLoadImg();PF('addData').hide();add();" >
</p:commandButton>
</p:dialog>

提交时如何获取选中项的值?

最佳答案

你可以使用 jSTL forEach 标签

<p:tabView id="myTabView">
<c:forEach var="tab" items="#{myBean.tabs}">
<p:tab title="#{tab.title}">
<ui:include src="#{tab.url}" />
</p:tab>
</c:forEach>
</p:tabView>

在你的 myBean 中构建列表进行迭代

List<MyTabObject> tabs = new ArrayList<MyTabObject>();
tabs.add(new MyTabObject("Tab Title", "/path/to/contentFile.xhtml"));

MyTabObject

    public class MyTabObject {
private String title;
private String url;

public MyTabObject() {

}

public MyTabObject(String title, String url) {
this.title = title;
this.url = url;
}
}

关于jsf - 如何在 PrimeFaces 5.0 中使用 tabView 获取动态选项卡名称和数据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35282711/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com