为什么当我抓住"模糊"时,PrimeFaces 5.3不会调用我的监听器功能?和#34;焦点"事件?

时间:2016-04-25 12:53:31

标签: ajax primefaces jsf-2.2

我的目的是显示填写文本区域组件的信息。当它获得焦点时我会显示信息,当它失去焦点时我会清除信息。我不希望获取任何输入值只是捕获焦点并模糊事件并调用侦听器并显示/清除消息。

我已阅读BalusC对条件渲染的评论,因此我将条件文本消息放入"始终呈现" JSF组件。

我的"总是呈现" f:outPutPanel组件显示在生成的XHTML代码中,但我的侦听器函数永远不会被调用。据我所知,primefaces监听器的方法签名只是void somefunction()不像jsf ajax监听器。 我还阅读了BalusC关于将@this包含在proccess属性中的评论,但在我看来,它似乎不合理,因为我不想捕获任何输入值。 我是JSF和primefaces的新手,所以感谢任何帮助。

我的相关观点摘录:

<h:form>
    <h:panelGroup layout="block" id="info">
        <h:outputText rendered="#{ebookController.infoMessage != null}" value="#{ebookController.infoMessage}"/>
    </h:panelGroup>
    ....
    <p:inputTextarea id="description" styleClass="form-control vspace"  required="true" requiredMessage="Kérlek, add meg az e-könyv rövid leírását" value="#{ebookController.newEbook.description}" rows="20" cols="30" counter="display" maxlength="500" counterTemplate="{0} karakter lehet még" autoResize="false" validatorMessage="Az e-könyv leírása maximum 500 karakterből állhat">
       <f:validateLength maximum="500"/>
       <p:ajax event="focus" process="@none" update="info" listener="#{ebookController.setTextAreaInfoMessage()}"/>
       <p:ajax event="blur" process="@none"  update="info" listener="#{ebookController.clearInfoMessage()}"/>
    </p:inputTextarea>
    <h:outputText id="display" />
</h:form>

我的相关java代码:

@Named(value = "ebookController")
@SessionScoped
public class EbookController implements Serializable {

private String infoMessage;

public String getInfoMessage() {
    return infoMessage;
}

public void setInfoMessage(String infoMessage) {
    this.infoMessage = infoMessage;
}

public void setTextAreaInfoMessage(){
    setInfoMessage("Tipp: Az e-könyved bemutatása során a fontos részeket emeld ki, és tagold a szöveget bekezdésekkel. Ha egy bekezdés végére értél, csak egy ENTER-t üss!");
}

public void clearInfoMessage(AjaxBehaviorEvent e){
        setInfoMessage("");
}
....
}

1 个答案:

答案 0 :(得分:0)

解决方案1:用户f:ajax

<f:ajax immediate="true" event="focus" process="@none" render="info"
                listener="#{ebookController.setTextAreaInfoMessage()}" />
<f:ajax immediate="true" event="blur" process="@none" render="info"
                listener="#{ebookController.clearInfoMessage()}" />

Managed Bean

public void setTextAreaInfoMessage() {
        System.out.println("setTextAreaInfoMessage");
        setInfoMessage(
                "Tipp: Az e-könyved bemutatása során a fontos részeket emeld ki, és tagold a szöveget bekezdésekkel. Ha egy bekezdés végére értél, csak egy ENTER-t üss!");
    }

    public void clearInfoMessage() {
        System.out.println("clearInfoMessage");
        setInfoMessage("");
    }

参考Problem with h:form and p:ajax