命令按钮在渲染时执行
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 代码(当然会立即执行
您可能打算改用 onclick
或 oncomplete
。与基本 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
问题:如何在网站呈现时阻止执行?
那是我的按钮所在的位置:
<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 代码(当然会立即执行
您可能打算改用 onclick
或 oncomplete
。与基本 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