0

プライムフェイスでセル編集を行う単純なデータテーブルがあります。それは機能しますが、最初に JavaScript メッセージを作成しません。次に、db に対して 15 個の同じクエリを作成します。(休止状態のコンソールで確認できます)コードは公式サイトのトークンです:

<h:form id="form">

    <p:growl id="messages" showDetail="true"/>

    <p:contextMenu for="clients" widgetVar="cMenu">
        <p:menuitem value="Edit Cell" icon="ui-icon-search" onclick="clientsTable.showCellEditor();return false;"/>
        <p:menuitem value="Hide Menu" icon="ui-icon-close" onclick="cMenu.hide()"/>
    </p:contextMenu>

    <p:dataTable id="clients" var="client" value="#{clientsBean.clients}" paginator="true" rows="5"
                 editable="true" editMode="cell" widgetVar="clientsTable">

        <p:ajax event="cellEdit" listener="#{clientsBean.onCellEdit}" update=":form:messages"/>

        <p:column headerText="Name" style="width:25%">
            <p:cellEditor>
                <f:facet name="output"><h:outputText value="#{client.name}"/></f:facet>
                <f:facet name="input"><p:inputText id="nameInput" value="#{client.name}"
                                                   style="width:96%"/></f:facet>
            </p:cellEditor>
        </p:column>

そのため、情報を編集して Enter キーを押すと、15 個のクエリが作成され、JS メッセージが表示されません。

Bean の getClients() は単純な hibernate クエリ (正常に動作) であり、onCellEdit() は次のようになります。

public void onCellEdit(CellEditEvent event) {  
    Object oldValue = event.getOldValue();  
    Object newValue = event.getNewValue();  

    if(newValue != null && !newValue.equals(oldValue)) {  
        FacesMessage msg = new FacesMessage(FacesMessage.SEVERITY_INFO, "Cell Changed", "Old: " + oldValue + ", New:" + newValue);  
        FacesContext.getCurrentInstance().addMessage(null, msg);  
    }  
} 

また、新しい奇妙なバグ apperead : その Bean の oldValue と newValue は常に同じです。

4

0 に答える 0