PrimeFaces 具有动态选项卡数量的“tabChange”事件

tro*_*roy 5 jsf primefaces

我需要获取 TabView 中当前活动选项卡的标题。TabView 由动态数量的选项卡构成,监听器附加到“tabChanged”:

<p:tabView value="#{bean.list}" var="listItem">
  <p:ajax event="tabChange" listener="#{listenerBean.onChange}" />
  <p:tab title="#{listItem.stringProperty}">
  </p:tab>
</p:tabView>
Run Code Online (Sandbox Code Playgroud)

问题是 onChange(TabChangeEvent event) 接收到的 TabChangeEvent 对象始终包含第一个选项卡而不是活动选项卡。

public void onChange(TabChangeEvent event) {
    event.getTab().getTitle(); //allways returns title of first tab
}
Run Code Online (Sandbox Code Playgroud)

如果我显式定义每个选项卡,则此行为仅适用于 TabView 中的动态选项卡数量,TabChangeEvent 工作正常。

有什么建议么?谢谢。

我将 PrimeFaces 3.5 与 JSF2.1 和 Servlet 2.5 一起使用

Smu*_*tje 1

下面的最小示例对我来说就像一个魅力,打印选项卡的标题以在每次单击它时激活:

页面.xhtml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
        "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"
      xmlns:f="http://xmlns.jcp.org/jsf/core"
      xmlns:p="http://primefaces.org/ui"
      xmlns:h="http://xmlns.jcp.org/jsf/html">
    <f:view>
        <h:head/>
        <h:body>
            <h:form>
                <p:tabView value="#{bean.items}"
                           var="item">
                    <p:ajax event="tabChange"
                            listener="#{bean.printTitle}"
                            update="@form"/>
                    <p:tab title="#{item}">
                    </p:tab>
                </p:tabView>
            </h:form>
        </h:body>
    </f:view>
</html>
Run Code Online (Sandbox Code Playgroud)

Bean.java

import javax.faces.view.ViewScoped;
import javax.inject.Named;
import java.io.Serializable;
import java.util.Arrays;
import java.util.List;

import org.primefaces.event.TabChangeEvent;

@Named
@ViewScoped
public class Bean implements Serializable {

    private final List<String> items = Arrays.asList("Hello", "This", "Is", "TabView");

    public List<String> getItems() {
        return items;
    }

    public void printTitle(TabChangeEvent event) {
        System.out.println("title = [" + event.getTab().getTitle() + "]");
    }
}
Run Code Online (Sandbox Code Playgroud)