2つのselectOneMenuがあり、最初のメニューの値が変更された場合は2番目の値を変更したいと思います。2つのメニューには、1980年から2012年までの年が含まれています。最初のメニューで1990を選択した場合、2番目のメニューでは1990年から2012年のみを指定します。
しかし、別の値を選択しても何も起こらず、この要素を分析すると次のメッセージが表示されます。
Uncaught TypeError: Cannot read property 'action' of null
A4J.Query
A4J.AJAX.PrepareQuery
A4J.AJAX.Submit
onchange
これが私が持っているものです:
<%-- Year filter --%>
<h:selectOneMenu id="minYear" value="#{statistics.minYear}"
style="width: 75px">
<f:selectItems value="#{statistics.minYearValues}" />
<a4j:support event="onchange" action="#{statistics.minYearChanged}"
reRender="maxYear"/>
</h:selectOneMenu>
<h:selectOneMenu id="maxYear" value="#{statistics.maxYear}"
style="width: 75px">
<f:selectItems value="#{statistics.maxYearValues}"/>
<a4j:support event="onchange" action="#{statistics.maxYearChanged}"
reRender="minYear" />
</h:selectOneMenu>
<%-- end year filter--%>
そしてここにマネージドBean:
public List getMinYearValues() {
this.minYear = MIN_YEAR;
this.minYearValues = fillYearValues(MIN_YEAR, maxYear);
return minYearValues;
}
public List getMaxYearValues() {
int min = this.minYear;
this.maxYearValues = fillYearValues(min, maxYear);
return maxYearValues;
}
private List fillYearValues(int min, int max) {
List values = new ArrayList();
for(int i = min; i <= max; i++) {
values.add(new SelectItem(i, String.valueOf(i)));
}
return values;
}
private int getPresentYear() {
Calendar cal = Calendar.getInstance();
cal.setTime(new Date());
return cal.get(Calendar.YEAR);
}
public void minYearChanged(ValueChangeEvent event) {
int newValue = new Integer(event.getNewValue().toString());
this.maxYearValues = fillYearValues(newValue, maxYear);
}
public void maxYearChanged(ValueChangeEvent event) {
int newValue = new Integer(event.getNewValue().toString());
this.minYearValues = fillYearValues(minYear, newValue);
}