0

我在使用 JSF / Primefaces 来显示弹出窗口时遇到问题。作为背景,我使用 JSF 模板来生成我的页面:

内联用于显示数据表,但是当我单击按钮显示对话框时,什么也没有发生。我在日志中看不到任何错误。

<h:body>
    <p:dataTable id="lstUsers" var="u" value="#{userController.userList}" selectionMode="single" 
                 selection="#{userController.selectedUser}" rowKey="#{u.login}" paginator="true" rows="10">
        <p:column headerText="Username">
            <h:outputLabel value="#{u.login}"></h:outputLabel>
        </p:column>
        <p:column headerText="Role" rowspan="2">
            <h:outputLabel value="#{u.role}"></h:outputLabel>
        </p:column>
        <f:facet name="footer">
            <p:commandButton id="bttAdd" type="button" value="Add" update=":contentView:idPanelPop" oncomplete="userDialog.show()" ></p:commandButton>
            <p:commandButton id="bttEdit" value="Edit"></p:commandButton>
            <p:commandButton id="bttRemove" value="Remove"></p:commandButton>
        </f:facet>
    </p:dataTable>
    <p:dialog id='userDialog' header="User Details" widgetVar="userDialog" 
              resizable="false" width="200px" height="200px" showEffect="clip" hideEffect="fold">
        <h:panelGrid  id="idPanelPop" columns="2">
            <h:outputLabel id='dOutUser' value="Username"></h:outputLabel>
            <h:outputLabel id='dOutUserValue' value="#{userController.selectedUser.login}"></h:outputLabel>

            <h:outputLabel id='dOutRole' value="Role"></h:outputLabel>
            <h:outputLabel id='dOutRoleValue' value="#{userController.selectedUser.role}"></h:outputLabel>
        </h:panelGrid>
    </p:dialog>
</h:body>

上面的代码用作

<ui:composition template="./maintemplate.xhtml"
                xmlns:h="http://java.sun.com/jsf/html"
                xmlns:p="http://primefaces.org/ui"
                xmlns:ui="http://java.sun.com/jsf/facelets">
    <ui:define id="contentViewIndex" name="content">
        <ui:include src="#{navigationController.currentPage}"></ui:include>
    </ui:define>
</ui:composition>

我的模板页面包含以下内容:

        <p:layoutUnit position="center">
                <h:form id="contentView">
                    <ui:insert name="content">
                            Default Content
                    </ui:insert>
                </h:form>    
        </p:layoutUnit> 

navigationController.current值会根据菜单单击更改以在页面间导航。我正在关注官方的 primafaces 展示PrimeFaces数据表

我当前的设置是 Netbeans 7.3 RC1 / Apache 7.0.34.0 / Mojarra 2.1.13

如果有人能指出我解决这个问题的正确方向,我会很感激:)

编辑:考虑到内联答案后没有任何效果。也许我应该先检查浏览器控制台,在这种情况下,这很奇怪,因为它抱怨它无法识别 widgedVar。我已经尝试将对话框放在表单之外,结果是相同的错误。:/

4

3 回答 3

0

您的bttAdd按钮是普通按钮(您使用type="button"属性明确设置它)。这意味着它只执行一些 JavaScript,没有任何 AJAX 请求。要执行 AJAX 请求,并更新您的面板,请删除type="button"并尝试。

于 2013-02-11T10:26:01.423 回答
0

我会改变两件事(首先可能不重要):

  1. 添加2个表格:一个里面有数据表,另一个里面有对话框
  2. 将 widgetVar="userDialog" 更改为独特的东西。widgetVar="userDialogWidget"
于 2013-02-11T12:05:58.690 回答
0

发现问题...

经过大量测试和挖掘并考虑到以前的答案。问题是两件事:

第一个。对角线的高度和宽度不能包含 px。

第二。根据之前的答案,它必须在 此处解释的外部。

p:dialog 的大小不能包含 px。

于 2013-02-12T12:07:08.257 回答