using templates in primefaces JSF

耗尽温柔 提交于 2019-12-25 02:06:05

问题


I have main page index.xhtml with declared place to put content dependent on page clicked.

            <br>
            <div id="centerContent">
        <ui:insert name="centerContent" >
              <ui:param name="mainTag" value="" />
        <ui:include src="/template/commonContent.xhtml" />
        </ui:insert>
                <h4>#{mainTag}</h4>
           </div>
            </br><br></br>
            <p:panel id="content">
                        <h:form>
    <h:inputText id="namez" ></h:inputText>
</h:form>
            </p:panel>       
        </p:layoutUnit>

my template commonContent is:

<?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"
      >
    <body>
        <ui:composition>
        <h1>Ubezpieczamy najlepiej!</h1>
        </ui:composition>
    </body>
</html>

and page for sending emails is:

<?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:h="http://java.sun.com/jsf/html"
      xmlns:ui="http://java.sun.com/jsf/facelets"
      >
    <h:body>

        <ui:composition template="index.xhtml">

            <ui:define name="centerContent">
                <h2>Zapytaj</h2>
                        <h:commandButton actionListener="#{mySendBean.sendMail2()}" value="Welcome Me">
            </h:commandButton>
                        <ui:param name="mainTag" value="Z chęcią odpowiemy" />
            </ui:define>


        </ui:composition>

    </h:body>

when commandButton is put on main pages it works, email is sent, but when loaded via template it didn't work. All things work but not <h:commandButton actionListener="#{mySendBean.sendMail2()}" value="Welcome Me">. Why it doesn't work when loaded via clicked template?

bean code:

import javax.faces.bean.ManagedBean;
import javax.faces.bean.SessionScoped;
import javax.mail.*;
import org.apache.commons.mail.DefaultAuthenticator;
import org.apache.commons.mail.Email;
import org.apache.commons.mail.EmailException;
import org.apache.commons.mail.SimpleEmail;


/**
 *
 * @author root
 */
@ManagedBean
@SessionScoped
public class mySendBean {

    private myEmailSend mE;
    /**
     * Creates a new instance of mySendBean
     */
    public mySendBean() {
        mE=new myEmailSend();
    }

    private static int j;

    /**
     * Get the value of j
     *
     * @return the value of j
     */
    public int getJ() {
        return j;
    }

    /**
     * Set the value of j
     *
     * @param j new value of j
     */
    public void setJ(int j) {
        this.j = j;
    }

        private String name="iop";

    /**
     * Get the value of name
     *
     * @return the value of name
     */
    public String getName() {
        return name;
    }

    /**
     * Set the value of name
     *
     * @param name new value of name
     */
    public void setName(String name) {
        this.name = name;
        sendMail2();
    }

    public String getSayWelcome(){
       //check if null?
       if("".equals(name) || name ==null){
        return "";
       }else{
        return "Ajax message : Welcome " + name;
       }
    }

    public void setSendMail(){
        sendMail2();
    }
    public void sendMail2(){ 
        j=getJ();
        setJ(++j);

        Email email = new SimpleEmail();
        try {
        //send mail
    }
}

回答1:


had to include content in <h:form>:

<?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:h="http://java.sun.com/jsf/html"
      xmlns:ui="http://java.sun.com/jsf/facelets"
      >
    <h:body>

        <ui:composition template="index.xhtml">

            <ui:define name="centerContent">
                    <h:form>
                        <ui:param name="mainTag" value="Z chęcią odpowiemy" />
                <h2>Zapytaj</h2>
                        <h4>#{mainTag}</h4>
                        <h:commandButton actionListener="#{mySendBean.sendMail2()}" value="Welcome Me">
            </h:commandButton>
                    </h:form>
            </ui:define>


        </ui:composition>

    </h:body>

</html>


来源:https://stackoverflow.com/questions/15993522/using-templates-in-primefaces-jsf

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!