命令按钮在渲染时执行

CommandButton execution while rendering

问题:如何在网站呈现时阻止执行?

那是我的按钮所在的位置:

<p:dialog widgetVar="newComment" height="200" width="500">
    <h:form>
        <h:panelGrid>
            <h:outputText value="#{commentDialog.username}" />
            <h:inputTextarea id="in_text" value="#{commentDialog.text}" />
            <p:message for="in_text" />
        </h:panelGrid>
        <p:commandButton validateClient="true" value="Abschicken" ajax="true"
            actionListener="#{popupRequestView.update}" action="PF('newComment').hide();update_popup();" />
    </h:form>
</p:dialog>

action 属性旨在在单击时执行支持 bean 操作方法,而不是打印一些 JavaScript 代码(当然会立即执行

您可能打算改用 onclickoncomplete。与基本 HTML 一样,那些 on* 属性旨在在指定的 HTML 事件期间执行一些 JavaScript 代码("click"、"complete"、等)。

oncomplete="PF('newComment').hide();update_popup();" 

到目前为止提供的信息中未显示的另一个原因是您忘记注册 p: XML 命名空间。任何 <p:xxx> 标签都将作为纯文本打印。验证标记中某处的父元素是否具有以下内容:

xmlns:p="http://primefaces.org/ui"

无论如何,暂停一下 JSF 并学习一些基础知识 HTML/JavaScript 并不是一个坏主意。毕竟,JSF 是 "just" 一个 HTML/CSS/JS 代码生成器。

您必须使用 primefaces ajaxStatus 以防止在渲染和执行时点击按钮 ajax

ajaxStatus in primefaces showcase