【发布时间】:2011-12-07 07:00:32
【问题描述】:
我正在尝试实现一个简单的 RichFaces 4 皮肤切换器,所以代码所做的只是在 bean 上设置一个新的 String 属性并重新渲染整个视图。这是 JSF:
<rich:panel styleClass="shadow">
...
<h:form style="float: right;">
<h:outputText value="Skin: " />
<h:selectOneMenu value="#{skinBean.skin}" id="skin-selector">
<f:ajax event="change" execute="@form" render="@all" listener="#{skinBean.listener}" />
<f:selectItem itemValue="DEFAULT" itemLabel="Default" />
<f:selectItem itemValue="classic" itemLabel="Classic" />
<f:selectItem itemValue="blueSky" itemLabel="Blue Sky" />
<f:selectItem itemValue="deepMarine" itemLabel="Deep Marine" />
<f:selectItem itemValue="emeraldTown" itemLabel="Emerald Town" />
<f:selectItem itemValue="japanCherry" itemLabel="Japan Cherry" />
<f:selectItem itemValue="ruby" itemLabel="Ruby" />
<f:selectItem itemValue="wine" itemLabel="Wine" />
</h:selectOneMenu>
</h:form>
</rich:panel>
这是皮豆:
@Named
@SessionScoped
public class SkinBean implements Serializable
{
private static final long serialVersionUID = 7477768262527797286L;
private static final Logger log = Logger.getLogger(SkinBean.class);
private String skin;
@PostConstruct
public void init()
{
log.info("Initializing skin bean!");
// default
this.skin = "wine";
}
@PreDestroy
public void remove()
{
log.info("Removing skin bean!");
}
public String getSkin()
{
return skin;
}
public void setSkin(String skinName)
{
log.info("Setting skin to " + skinName);
this.skin = skinName;
}
public void listener(AjaxBehaviorEvent abe)
{
// log.info("Skinning event!" + abe);
}
}
登录选择更改:
07:34:49,869 INFO [com.company.project.util.PhaseTracker] (http--127.0.0.1-8080-5) After RESTORE_VIEW 1
07:34:49,870 INFO [com.company.project.util.PhaseTracker] (http--127.0.0.1-8080-5) Before APPLY_REQUEST_VALUES 2
07:34:49,871 INFO [com.company.project.util.PhaseTracker] (http--127.0.0.1-8080-5) After APPLY_REQUEST_VALUES 2
07:34:49,871 INFO [com.company.project.util.PhaseTracker] (http--127.0.0.1-8080-5) Before PROCESS_VALIDATIONS 3
07:34:49,871 INFO [com.company.project.util.PhaseTracker] (http--127.0.0.1-8080-5) After PROCESS_VALIDATIONS 3
07:34:49,871 INFO [com.company.project.util.PhaseTracker] (http--127.0.0.1-8080-5) Before UPDATE_MODEL_VALUES 4
07:34:49,872 INFO [com.company.project.skin.SkinBean] (http--127.0.0.1-8080-5) Setting skin to classic
07:34:49,872 INFO [com.company.project.util.PhaseTracker] (http--127.0.0.1-8080-5) After UPDATE_MODEL_VALUES 4
07:34:49,872 INFO [com.company.project.util.PhaseTracker] (http--127.0.0.1-8080-5) Before INVOKE_APPLICATION 5
07:34:49,872 INFO [com.company.project.util.PhaseTracker] (http--127.0.0.1-8080-5) After INVOKE_APPLICATION 5
07:34:49,872 INFO [com.company.project.util.PhaseTracker] (http--127.0.0.1-8080-5) Before RENDER_RESPONSE 6
07:34:50,226 INFO [com.company.project.util.PhaseTracker] (http--127.0.0.1-8080-5) After RENDER_RESPONSE 6
我的日志清楚地显示新值设置正确,但它不会更新视图。它只会在重新加载整个页面时更新(这有点毫无意义)。
有人知道为什么视图没有更新吗?我还尝试了一些 ID 而不是 render="@all",例如render=":repo-form"(在切换器表单之外),但没有任何反应。寻找错误也没有发现任何有用的东西。即使是明确的 ID 也无法更新,这让我觉得有些不同……?
注意:我在 JBoss AS 7.0.1 上使用 Mojarra 2.0.4。
谢谢
【问题讨论】:
标签: java ajax jsf jsf-2 richfaces