繁体   English   中英

primefaces selectOneMenu如何重新加载

[英]primefaces selectOneMenu how to reload

我在项目中使用了3个selectOneMenu组件。 我需要在第一次更改后重新加载第二个内容。 以下是文件的一些部分

的index.xhtml

<h:form id="form">
<p:selectOneMenu id="Rząd" value="#{birdSelectorBean.selectedState}" effect="fade"
style="width: 150px;">  
<f:selectItem itemLabel="Rząd" itemValue="" />  
<f:selectItems value="#{birdSelectorBean.rzad}" />  
<p:ajax render="@form" listener="#{birdSelectorBean.stateChangeListener}" />
</p:selectOneMenu> 

<p:selectOneMenu id="rodzina" value="#{birdSelectorBean.selectedState}" effect="fade"
style="width: 150px;">  
<f:selectItem itemLabel="Rodzina" itemValue="" />
<f:selectItems value="#{birdSelectorBean.rodzina}" />
</p:selectOneMenu>

<p:selectOneMenu id="rodzaj" value="#{birdSelectorBean.selectedState}" effect="fade"
style="width: 150px;">  
<f:selectItem itemLabel="Rodzaj" itemValue="" />   
<f:selectItems value="#{birdSelectorBean.rodzaj}" />
</p:selectOneMenu>
</h:form>

BirdSelectionBean.java:

public class BirdSelectorBean
{
private String selectedState;
private List<SelectItem> rzad;
private List<SelectItem> rodzina;
private List<SelectItem> rodzaj;

public BirdSelectorBean()
{
    rzad = new ArrayList<>();
    rzad.add(new SelectItem("Rząd_X"));
    rzad.add(new SelectItem("Rząd_Y"));
    rzad.add(new SelectItem("Rząd_Z"));

    rodzina = new ArrayList<>();
    rodzaj = new ArrayList<>();
}

public void stateChangeListener(ValueChangeEvent event)
{
    rodzina.clear();
    rodzina.add(new SelectItem("Rodzina_A"));
    rodzina.add(new SelectItem("Rodzina_B"));
    rodzina.add(new SelectItem("Rodzina_C"));
}
...
getters and setters
...
}

我阅读了很多相关主题,但它对我不起作用。 我试过update =“rodzina”,就像它在这里的示例一样,渲染选项就像在该主题中说的那样:但它仍然不起作用。 请帮我 :]

p:ajax标签中,将render="@form"改为update="@form" 渲染由f:ajax使用,由于某种原因,primefaces使用另一个名称 - 请参阅此处

看起来你的stateChangeListener方法被调用了,更重要的是,你的托管bean看起来没有任何范围(至少来自你的问题内容),请记住它必须至少是@ViewScoped才能使其工作。 此外,您的代码中的另一个问题是您使用相同的属性来选择三个<p:selectOnuMenu> (这还不是问题,因为您还没有达到您想要的开始)。

要使ajax更新起作用,请从stateChangeListener删除该参数。 另外,让我们从下拉列表中为所选项添加其他两个属性。

@ManagedBean
@ViewScoped
public class BirdSelectorBean {

    private String selectedState;
    private String selectedStateRodzina;
    private String selectedStateRodzaj;
    //other fields and methods...

    public void stateChangeListener() {
        rodzina.clear();
        rodzina.add(new SelectItem("Rodzina_A"));
        rodzina.add(new SelectItem("Rodzina_B"));
        rodzina.add(new SelectItem("Rodzina_C"));
    }
}

然后在<p:ajax>调用中更新所需的<p:selectOneMenu> (我从类似样式的组件中删除了与问题属性无直接关系):

<p:selectOneMenu id="Rząd" value="#{birdSelectorBean.selectedState}">
    <f:selectItem itemLabel="Rząd" itemValue="" />
    <f:selectItems value="#{birdSelectorBean.rzad}" />
    <p:ajax update="rodzina" listener="#{birdSelectorBean.stateChangeListener}" />
</p:selectOneMenu>

<p:selectOneMenu id="rodzina" value="#{birdSelectorBean.selectedStateRodzina}">
    <f:selectItem itemLabel="Rodzina" itemValue="" />
    <f:selectItems value="#{birdSelectorBean.rodzina}" />
</p:selectOneMenu>

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM