当前位置: 首页 > 知识库问答 >
问题:

Primefaces在单元格编辑后更新表

沈俊晤
2023-03-14

我有一个带有单元格编辑功能的数据表,我想通过应用一个不同样式的类来更新数据表以显示修改后的记录。

以下是我的问题:

  • 如果在激发onCellEdit事件时未更新数据表,则记录已正确更新,但无法看到已修改行的applyed style类。
  • 如果在onCellEdit事件激发时更新数据表,并使用return键更新值,则一切正常,并且可以看到修改行的应用样式类。
  • 如果我在单元格编辑事件触发时更新数据表,并使用鼠标clic更新值(单击另一行或同一行内的另一个单元格),则仅正确更新第一个值;尝试更新其他值时,onCellEdit事件会在我可以插入新值之前触发,因此该事件会以NewValue=OldValue触发所有后续更改。

xhtml页面:

<h:form id="frm_tbl_riv">
  <p:dataTable id="tbl_rilevazioni" var="rilevazione"
    value="#{rilevazioni.rilevazioni}" widgetVar="tbl_rilevazioni_id"
    editable="true" editMode="cell" scrollable="true" scrollHeight="350"
    rowKey="#{rilevazione.idRilevazione}" selectionMode="single"
    selection="#{rilevazioni.selezionata}">
    <p:ajax event="rowSelect"
      update=":tView:frm_tbl_riv:popup_rilevazioni" />
    <p:ajax event="cellEdit" listener="#{rilevazioni.onCellEdit}"
      update=":tView:frm_btn_riv" />
      <!-- update=":frm_btn_riv :frm_tbl_riv" -->
    <p:ajax event="contextMenu"
      listener="#{rilevazioni.onRilevazioneSelezionata}"
      update="@this" />

    <p:column headerText="#{msg['rilevazione']}" width="130">
      <f:facet name="header">
        <h:outputText value="#{msg['rilevazione']}" />
      </f:facet>
      <h:outputText value="#{rilevazione.descRilevazione}" id="descRil" />
    </p:column>
    <p:column headerText="#{msg['valore']}"
      styleClass="#{rilevazioni.isModificata(rilevazione) ? 'modificata' : ''}"
      width="30">
      <h:outputText value="#{rilevazione.valore}"
        rendered="#{!rilevazioni.isModificabile(rilevazione)}" />
      <p:cellEditor
        rendered="#{rilevazioni.isModificabile(rilevazione)}">
        <f:facet name="output">
          <h:outputText value="#{rilevazione.valore}" />
        </f:facet>
        <f:facet name="input">
          <p:inputText value="#{rilevazione.valore}"
            label="#{msg['valore']}">
        </f:facet>
      </p:cellEditor>
    </p:column>
  </p:dataTable>
</h:form>

和托管bean(视图范围):

@ManagedBean(name = "rilevazioni")
@ViewScoped
public class GestioneRilevazioniBean implements Serializable
{
  // ...

  public void onCellEdit(CellEditEvent event)
  {
    FacesContext context = FacesContext.getCurrentInstance();
    FacesMessage msg = null;
    Object nuovoValore = event.getNewValue();
    Object vecchioValore = event.getOldValue();
    int i = event.getRowIndex();
    RilevazioneGiornaliera r = rilevazioni.get(i);

    r.setIdUtente(userBean.getUserId());

    if (!nuovoValore.equals(vecchioValore))
    {
      try
      {
        RilevazioniService.getInstance().updateRilevazioneGiornaliera(r);
        modificate.add(r);
      } catch (Throwable ex)
      {
        // ...
      }
    }
  }

  public boolean isModificata(RilevazioneGiornaliera riv)
  {
    return modificate.contains(riv);
  }

  public boolean isModificabile(RilevazioneGiornaliera rilevazione)
  {
    // some logic
    return true;
  }
}

如果我使用:

update=":frm_btn_riv :frm_tbl_riv"

对于on-cell编辑事件,我获得在点2和点3上指定的行为。与@form或@parent相同。

共有1个答案

云默
2023-03-14

我创建了一个解决方案,在onCellEdit事件激发后将style类更新到修改后的单元格。

数据表:

<p:ajax event="cellEdit" listener="#{rilevazioni.onCellEdit}"
    oncomplete="handleRilevazioniCellEdit(xhr, status, args);" />
// ...
// within the cell editor
<p:inputText id="rilevazioniCellEditInputtext" value="#{rilevazione.valore}"
        label="#{msg['valore']}" />

JavaScript:

<script>
function handleRilevazioniCellEdit(xhr, status, args)
{
    var modelInput = $('#parentId:' + args.rowIndex + '\\:rilevazioniCellEditInputtext');
    var cell = modelInput.parent().parent().parent();
    cell.addClass('modificata');
}
</script>

托管bean,在onCellEdit()事件结束时:

RequestContext requestContext = RequestContext.getCurrentInstance();
requestContext.addCallbackParam("rowIndex", event.getRowIndex());
 类似资料:
  • 我有一个带有单元格编辑的primefaces datatable,它可以在视图中的一个布尔变量上切换。 我有三个问题: 在编辑模式下,我更改了一个值,然后单击页面上的“保存”按钮,它不会保留新值,如果我先单击页面上的任何其他位置,然后单击“保存”,它将保留该值。如果您先单击“保存”,我需要它来保留值。 如果我编辑了一个输入文本的单元格,然后我单击了它,那么该字段现在就是一个输出文本,直到我再次单击

  • 在我的datatable中,根据列“Délai Action”,当没有日期时,其他列必须是红色的。最后一列有一个黄色/橙色/红色的球图标,取决于日期。那么如何更新行,然后显示红色或不红色的列和对应的色球呢? 我尝试了不同的方法,比如: 也可以在我的enregistrer()方法中使用: 提前致谢 Primefaces 6.0/JSF 2.3

  • 这是豆子 这里的问题是连//////////////////都没有显示,这意味着HTML代码中存在问题,阻止了onCellEdit函数的执行!!!

  • 我使用进行单元格编辑,并在Editable=true的上使用验证器。如果选择的P:SelectoneMenu值或键入的值无效,我希望单元格编辑状态保持在编辑模式(第二个屏幕截图),并像使用常规表单(第三个屏幕截图)一样在输入周围显示红色框。当验证失败时,会显示咆哮和消息,但下拉框周围的红色框不会持续存在,我担心用户可能不会注意到(第一张屏幕截图)。我不知道如何进行ajax更新来显示红色框,但保持单

  • 我有行编辑的dataTable,但我不需要编辑我的一个单元格(user.username)。我怎样才能做到这一点?这可能吗?我尝试删除一个单元格的p:cellEditor,但它在我的平板电脑上不起作用,因为当我在DataTable中使用它时,该列为空。 谢谢 我的代码:

  • 我想在单击该行中的一个按钮后更新primefaces数据表中的一列。 我的jsf页面: 我的访客Bean: visitService将间隙从OK更改为NOK,但我的datatables列没有更改。有什么想法吗? 表面5.2 我已经研究了如何只更新primefaces数据表中的特定单元格,但这似乎并没有解决它。