0

レンダリングするラベルを決定する値を持つドロップダウンがある単純な jsf ページを作成しようとしています。最初は、バッキング Bean コンストラクターを介して、すべてのラベルのレンダリングが false に設定されます。しかし、ラベルのそれぞれの値を true に設定する submit onchange を呼び出しました。設定されている値が変更時に削除されないように、バッキング Bean のスコープをセッションとして設定しました。ただし、ラベルは変更時にレンダリングされません。以下は、jsf ページのコード スニペットです。

<h:form>

    <h:panelGroup>
    <h:outputLabel styleClass="captionOutputField" value="Select Report Type:" />
<h:selectOneMenu id="selectedMenu" onchange="submit()" valueChangeListener="#{ReportHealth.typeSelectDropDownChange}">
        <f:selectItem itemLabel="" itemValue="empty" />
        <f:selectItem itemLabel="daily" itemValue="daily" />
        <f:selectItem itemLabel="weekly" itemValue="weekly" />
        <f:selectItem itemLabel="monthly" itemValue="monthly" />
</h:selectOneMenu>
<h:panelGroup rendered="#{ReportHealth.daily}">
    <h3>MENU 0</h3>
</h:panelGroup>
<h:panelGroup rendered="#{ReportHealth.weekly}">
    <h3>MENU 1</h3>
</h:panelGroup>
    <h:panelGroup rendered="#{ReportHealth.monthly}">
    <h3>MENU 2</h3>
</h:panelGroup>

バッキング Bean は次のとおりです。

public class ReportHealth implements Serializable{

private static final long serialVersionUID = 1L;

private boolean weekly;
private boolean monthly;
private boolean daily;
private String menuValue;



public ReportHealth() {
    weekly = false;
    monthly = false;
    daily = false;
}

public String getMenuValue() {
    return menuValue;
}

public void setMenuValue(String menuValue) {
    this.menuValue = menuValue;
}

public boolean isWeekly() {
    return weekly;
}

public void setWeekly(boolean weekly) {
    this.weekly = weekly;
}

public boolean isMonthly() {
    return monthly;
}

public void setMonthly(boolean monthly) {
    this.monthly = monthly;
}

public boolean isDaily() {
    return daily;
}

public void setDaily(boolean daily) {
    this.daily = daily;
}

public void typeSelectDropDownChange(ValueChangeEvent e)
{
    String typeSelectVal = e.getNewValue().toString();
    if(typeSelectVal!=null && typeSelectVal.equalsIgnoreCase("daily"))
    {
        setDaily(true);
        setWeekly(false);
        setMonthly(false);
    }
    else if(typeSelectVal!=null && typeSelectVal.equalsIgnoreCase("weekly"))
    {
        setDaily(false);
        setWeekly(true);
        setMonthly(false);
    }
    else if(typeSelectVal!=null && typeSelectVal.equalsIgnoreCase("monthly"))
    {
        setDaily(false);
        setWeekly(false);
        setMonthly(true);
    }
    else
    {
        setDaily(false);
        setWeekly(false);
        setMonthly(false);
    }
}


}
4

2 に答える 2

0

単純なタスクに複雑なコードを使用している理由がわかりません。ここにあなたが必要とするものがあります

<h:form>
 <h:panelGroup>
 <h:outputLabel styleClass="captionOutputField" value="Select Report Type:"/>
<h:selectOneMenu id="selectedMenu" value="#{reportHealth.menuValue}">
    <f:selectItem itemLabel="" itemValue="empty" />
    <f:selectItem itemLabel="daily" itemValue="daily" />
    <f:selectItem itemLabel="weekly" itemValue="weekly" />
    <f:selectItem itemLabel="monthly" itemValue="monthly" />
    <f:ajax render="@form">
                    </f:ajax>
 </h:selectOneMenu>
 <h:panelGroup rendered="#{reportHealth.menuValue eq 'daily'}">
  <h3>MENU 0</h3>
 </h:panelGroup>
 <h:panelGroup rendered="#{reportHealth.menuValue eq 'weekly'}">
  <h3>MENU 1</h3>
 </h:panelGroup>
 <h:panelGroup rendered="#{reportHealth.menuValue eq 'monthly'}">
  <h3>MENU 2</h3>
 </h:panelGroup>
 </h:panelGroup>
</h:form>

そしてビーンは

@ManagedBean
@ViewScoped
public class ReportHealth implements Serializable{

 private static final long serialVersionUID = 1L;

 private String menuValue;

 public String getMenuValue() {
    return menuValue;
 }

 public void setMenuValue(String menuValue) {
    this.menuValue = menuValue;
 }

}
于 2016-02-19T16:55:24.783 に答える
0

自分のコードの何が問題なのかがわかりました。<H3>ラベルをタグに入れる代わりに。<h:outputText>タグに入れる必要がありました。

于 2016-02-24T07:28:43.153 に答える