我正在使用 Primefaces 3.5 和 JSF2.1 (Mojarra) 开发一个项目
我创建了一个primefaces<p:tabView id="tabsVw" dynamic="false">
里面有两个选项卡,每个选项卡都有一个 primefaces 数据表
<h:form>
<p:tabView dynamic="false">
<p:ajax event="tabChange" listener="#{tstTab.onDtlTabChanged}" />
<p:tab title="tab1">
<p:dataTable value="#{tstTab.list1}" var="v1">
<p:column>
<h:outputText value="#{v1}"/>
</p:column>
</p:dataTable>
</p:tab>
<p:tab title="tab2">
<p:dataTable value="#{tstTab.list2}" var="v2">
<p:column>
<h:outputText value="#{v2}"/>
</p:column>
</p:dataTable>
</p:tab>
</p:tabView>
</h:form>
和 bean 内部(视图范围)
@ManagedBean
@ViewScoped
public class TstTab {
private List<String> list1;
private List<String> list2;
public TstTab(){
list1 = new ArrayList<String>();
list2 = new ArrayList<String>();
list1.add("List 1 - Str 1");
list1.add("List 1 - Str 2");
list1.add("List 1 - Str 3");
list1.add("List 1 - Str 4");
list1.add("List 1 - Str 5");
list2.add("List 2 - Str 1");
list2.add("List 2 - Str 2");
list2.add("List 2 - Str 3");
list2.add("List 2 - Str 4");
list2.add("List 2 - Str 5");
}
public void onDtlTabChanged(TabChangeEvent event) {
System.out.println("000000000000000000");
}
public List<String> getList1() {
System.out.println("11111111111111");
return list1;
}
public List<String> getList2() {
System.out.println("222222222222222222");
return list2;
}
}
现在的问题是运行应用程序并尝试在选项卡之间导航(更改)时,但我可以看到onDtlTabChanged
在调用 getter 之后调用,所以这是一个大问题。
如果改变tabView
从静态到动态,则行为是随机的,换句话说,对更改事件的调用发生在 getter 中间的某个位置。
先感谢您。
嗯,我认为这是一个 primefaces BUG,我找到了一个解决方法,如下所示
不要使用全局表单(tabView 本身的表单),而是为每个选项卡使用一个表单(在其中围绕数据表)
您必须添加一个虚拟选项卡作为第一个选项卡,该选项卡必须包含一个表单,其中包含一些静态数据或预加载的数据
就这样,
问题是ajax请求位于全局表单内,它导致数据表在ajax请求之前首先获取数据,
Primefaces 的奇怪之处在于,如果您不添加第一个虚拟选项卡,它将始终执行选项卡内的第一个表单并获取其数据,这将导致问题
问候 ,
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)