1

使用以下代码,两个选项卡的内容在 tabChange 事件中被清除,而不是被更新:

<h:form id="form">
    <p:tabView id="tabview">
        <p:ajax event="tabChange" listener="#{testBean.onChange}" update="@form"/>
        <p:tab title="Tab 1">
            <h:outputText value="Lorem ipsum dolor sit amet." id="ht1"/>
        </p:tab>
        <p:tab title="Tab 2">
            <h:outputText value="Donec et mi et arcu commodo hendrerit." id="ht2"/>
        </p:tab>
    </p:tabView>
</h:form>

onChange 方法是一个空方法是我的测试代码。

我在这里遗漏了一些东西,但我找不到什么。我究竟做错了什么?

编辑

我正在使用 ViewScoped bean。

我试过了update="@form",同样的问题出现了。update=":form"update=":form:tabview"

如果我使用update="ht1, ht2",一切都很好,但是在我的 onChange 方法中,我想以编程方式选择我想要激活的选项卡(在我的真实代码中有一种处理方法可以验证一些数据:如果验证失败,我想留在标签1,如果没问题,转到标签2)。为了实现这一点,我想我必须更新整个 tabview 组件,而不仅仅是标签的内容。但也许我错了?

完整代码

我做了一些更改,这是我更新的代码,但仍然无法正常工作。

托管豆:

import java.io.Serializable;
import javax.faces.bean.ManagedBean;
import javax.faces.bean.ViewScoped;
import org.primefaces.event.TabChangeEvent;

@ManagedBean
@ViewScoped
public class TestBean implements Serializable {

    private int idx;
    private String s1 = "test 1";
    private String s2 = "test 2";

    public TestBean() {
        System.out.println("TestBean.init");
    }

    public void onChange(TabChangeEvent e){
        s1 = "TEST TEST";
        s2 = "TEST TEST";
    }

    public int getIdx() {
        return idx;
    }

    public void setIdx(int idx) {
        this.idx = idx;
    }

    public String getS1() {
        return s1;
    }

    public void setS1(String s1) {
        this.s1 = s1;
    }

    public String getS2() {
        return s2;
    }

    public void setS2(String s2) {
        this.s2 = s2;
    }
}

小面:

<?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:h="http://java.sun.com/jsf/html"
      xmlns:p="http://primefaces.org/ui">
    <h:head>
        <title>Facelet Title</title>
    </h:head>
    <h:body>
        <h:form id="form">
            <p:tabView id="tabview" activeIndex="#{testBean.idx}">
                <p:ajax event="tabChange" listener="#{testBean.onChange}" update="@form"/>
                <p:tab title="Tab 1">
                    <h:outputText value="#{testBean.s1}" id="ht1"/>
                </p:tab>
                <p:tab title="Tab 2">
                    <h:outputText value="#{testBean.s2}" id="ht2"/>
                </p:tab>
            </p:tabView>
            <h:messages/>
        </h:form>
    </h:body>
</html>

更新

我将我的 Primefaces jar 从 3.4 更改为 3.2 和魔术,这种行为不再发生。然后我尝试了 3.3 和繁荣,错误。我将在 Primefaces 论坛上询问这是否是一个已知错误。

4

2 回答 2

6

你应该使用 activeIndex

 <p:tabView id="tabview" activeIndex="#{testBean.tabIndex}" >

并在您的 onchange 方法中,在验证后设置正确的 tabindex。

于 2013-05-13T13:24:44.640 回答
2

activeIndex绑定属性是不够的。您还必须触发 AJAX 提交以更新服务器上的值。所以应该是:

<p:tabView activeIndex="#{bean.index}">
    <p:ajax event="tabChange" />
</p:tabView>
于 2015-04-13T15:07:06.087 回答