JSF如何通过selectOneRadio的onchange提交表单

时间:2012-08-01 14:06:28

标签: java jsf jsf-2 primefaces

我正在尝试在选择selectOneRadio值时提交表单。我有下面的代码,但它没有进入我的#{contentEditorBacking.addNewsArticle}

有人知道在点击selectOneRadio时我如何进入该方法吗?

<p:panel header="News Article Title">
    <h:panelGrid columns="2">
        <h:outputLabel for="title" value="Title" style="font-weight: bold;"/>
        <p:inputText id="title" required="true" value="#{contentEditorBacking.newsTitle}" />
        <h:outputLabel value="Site" />
        <p:selectOneRadio value="#{contentEditorBacking.selectedNews}" layout="pageDirection" onchange="submit()">
            <f:selectItem itemLabel="Public" itemValue="Public" />
            <f:selectItem itemLabel="Member" itemValue="Member" />
        </p:selectOneRadio>
        <p:commandButton value="submit" action="#{contentEditorBacking.addNewsArticle}" />
    </h:panelGrid>
</p:panel>

1 个答案:

答案 0 :(得分:9)

两个问题:

  • 拦截单选按钮(和复选框)中的“更改”您需要click事件。
  • 默认情况下,<p:commandButton>是一个ajax按钮,它不像JS submit()那样为同步提交做好准备。

只需使用<p:ajax>代替,以便提交由ajax执行。请注意,您无需指定event属性,默认为click

<p:selectOneRadio value="#{contentEditorBacking.selectedNews}" layout="pageDirection">
    <f:selectItem itemLabel="Public" itemValue="Public" />
    <f:selectItem itemLabel="Member" itemValue="Member" />
    <p:ajax listener="#{contentEditorBacking.addNewsArticle}" />
</p:selectOneRadio>
<p:commandButton value="submit" action="#{contentEditorBacking.addNewsArticle}" />

根据评论

更新,您似乎想要导航到带有参数的其他页面。 addNewsArticle()方法应如下所示,以便与<p:ajax listener><p:commandButton action>兼容。

public void addNewsArticle() throws IOException {
    ExternalContext ec = FacesContext.getCurrentInstance().getExternalContext();
    ec.redirect(ec.getRequestContextPath() + "/next.xhtml?action=add");
}