作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我需要动态显示选项卡名称。每个选项卡都会有自己的数据列表。例如如果选项卡名称是“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/
我是一名优秀的程序员,十分优秀!