primefaces p:没有调用menuitem actionlistener

时间:2013-07-08 00:46:32

标签: jsf primefaces menuitem

我使用的是Mojarra 2.1.23和Primefaces 3.5。我正在尝试使这段代码工作,但由于某种原因,我无法调用侦听器。

<h:form id="menu" >
    <p:growl id="messages" autoUpdate="true" showDetail="true" />
    <p:panelMenu>
        <p:submenu label="Ajax Menuitems">
            <p:menuitem value="#{MenuController.test}"
                actionListener="#{MenuController.save}" ajax="true" 
                update="messages" />
            <p:menuitem value="Update" actionListener="#{MenuController.save}"
                update="messages" />
        </p:submenu>
    </p:panelMenu>
</h:form>

MenuController是由Spring 3管理的会话范围bean,甚至其属性也在相同的xhtml上正确显示(按钮显示文本“Save”)。

MenuController类如下:

public class MenuController() implements Serializable{

    public static Logger log;
    public String test="Save";

    public MenuController() {
        log = LoggerFactory.getLogger(this.getClass());
        log.debug("Hello MenuController.");
    }

    public void save(ActionEvent event) {  
        addMessage("Data saved");  
        log.debug(" saving");
    }

    public void addMessage(String summary) {  
        FacesMessage message = new FacesMessage(FacesMessage.SEVERITY_INFO,
            summary,  null);  
        FacesContext.getCurrentInstance().addMessage(null, message);  
    }
    //getters and setters...
}

我也在使用facelets,以下是Layout.xhtml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" 
xmlns:ui="http://java.sun.com/jsf/facelets"
xmlns:f="http://java.sun.com/jsf/core" 
xmlns:h="http://java.sun.com/jsf/html"
xmlns:p="http://primefaces.org/ui">

<h:head>

<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />

 <title><ui:insert name="title" /></title>
 </h:head>
 <h:body>
<div id="layout">       
<table>
<tr>
    <td>
    <div id="menu">
        <ui:include src="menu.xhtml"/>
    </div>

    </td>
    <td>
    <div id="content">
        <ui:insert name="content">              
        </ui:insert>
    </div>
    </td>   
</tr>
<tr>
<td>
    <div id="footer">
        <p><a href="#">© Footer</a></p>
    </div>
</td>
</tr>           
</table>
</div>

单击菜单项时,不会调用该方法。

1 个答案:

答案 0 :(得分:2)

通过将表单上的id从“menu”更改为“menuForm”来解决问题,不要被ID为“menu”的布局上的ID混淆

<h:form id="menuForm" >
   <p:growl id="messages" autoUpdate="true" showDetail="true" />
    <p:panelMenu>
     <p:submenu label="Ajax Menuitems">
        <p:menuitem value="#{MenuController.test}"
            actionListener="#{MenuController.save}" ajax="true" 
            update="messages" />
        <p:menuitem value="Update" actionListener="#{MenuController.save}"
            update="messages" />
    </p:submenu>
   </p:panelMenu>
</h:form>