我有两个 selectOneMenus,如果第一个菜单中的值已更改并向后更改,我想更改第二个的值。这两个菜单都填写了从 1980 年到 2012 年的年份。如果我在第一个菜单中选择 1990,我希望在第二个菜单中只有 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);
}