2013-10-02 15 views
6

我想要使用允许用户编辑表格本身中的行数据的素数面的特征。我已经沿着这个链接来实现它:在primefaces的行编辑中的event.getObject()发送旧值到bean

http://www.primefaces.org/showcase/ui/datatableRowEditing.jsf

当我说编辑的用户,其被输入不会发送到bean.It新值仍然只显示旧值。

我在JSF代码:

<p:dataTable value="#{mybean.userList}" 
     var="item" 
     id="dataTab" 
     widgetVar="usersTable" 
     tableStyleClass="data" paginator="true" rows="5" 
     filteredValue="#{userController.filteredUsers}" 
     editable="true" 
     rowKey="#{item}"> 

    <p:ajax event="rowEdit" listener="#{mybean.onEdit}" update=":userForm:growl" /> 
    <p:ajax event="rowEditCancel" listener="#{mybean.onCancel}" update=":userForm:growl" /> 
    <f:facet name="header"> 
     <p:outputPanel> 
      <h:outputText value="Search all fields:" /> 
      <p:inputText id="globalFilter"  onkeyup="('usersTable').filter()" style="width:150px" /> 
     </p:outputPanel>  
    </f:facet> 


    <p:column sortBy="#{item.firstName}" filterBy="#{item.firstName}" 
     filterMatchMode="startsWith"> 
     <p:cellEditor> 
      <f:facet name="header"> 
       <h:outputText value="First Name" /> 
      </f:facet> 
      <f:facet name="output"> 
       <h:outputText value="#{item.firstName}" /> 
      </f:facet> 
      <f:facet name="input"> 
       <p:inputText value="#{item.firstName}" style="width:100%"/> 
      </f:facet> 
     </p:cellEditor> 
    </p:column> 
    <p:column sortBy="#{item.lastName}" filterBy="#{item.lastName}" filterMatchMode="startsWith"> 
     <p:cellEditor> 
      <f:facet name="header"> 
       <h:outputText value="Last Name" /> 
      </f:facet> 

      <p:column headerText="Update" style="width:6%"> 
       <p:rowEditor /> 
      </p:column>  


</p:dataTable> 

我的代码在豆:

public String onEdit(RowEditEvent event) { 
    User user=(User)event.getObject()); 
    user.getFirstName(); 
} 

代码在bean用于获取在UI中的列表:

public List<UserBean> getUsersList(){ 
     List<UserBean> retval = new ArrayList<>();    
     for (Object[] tuple : myFacade.getUserList()) { 
      UserBean ub = new UserBean(); 
      ub.setFirstName((String) tuple[0]); 
      ub.setLastName((String)tuple[1]); 
      ub.setEmailAddress((String)tuple[2]); 
      ub.setOfficeNumber((String)tuple[3]); 
      ub.setRole((String)tuple[4]);     
      retval.add(ub); 
     } 
     return retval; 
    } 

我曾尝试在一些帖子中给出的建议,但他们没有工作。任何人都可以让我知道如何获得新的价值。我使用g lassfish 4.0,primefaces 3.5。

+0

在其他可能的问题中,您的代码没有正确关闭JSF标记。这是一个复制和粘贴问题? – patstuart

+0

听起来像转换/验证失败。你可以添加一个消息组件到你的表单来验证? – kolossus

+0

@patstuart是这只是一个复制粘贴错误,并在我的jsf页面罚款。 – Valla

回答

8

我能弄清楚问题..每当我在getter方法中获取列表时,我正在调用数据库来加载数据..但是这应该只在列表为null时完成。下面的代码给你一个清晰的画面:

public List<UserBean> getUsersList(){ 


     if(retval == null) 
     { 
      retval = new ArrayList<>(); 

      for (Object[] tuple : myFacade.getUserList()) { 
      UserBean ub = new UserBean(); 
      ub.setFirstName((String) tuple[0]); 
      ub.setLastName((String)tuple[1]); 
      ub.setEmailAddress((String)tuple[2]); 
      ub.setOfficeNumber((String)tuple[3]); 
      ub.setRole((String)tuple[4]); 

      retval.add(ub); 
     } 
     } 
     return retval; 
    } 

所以getUsersList在p我的VAR值:数据表,现在当我叫onEdit它将检查清单,如果它为null,做一个数据库调用或不会调用数据库。

+0

我有同样的问题,这是正确的答案。谢谢! – akelec

+2

在getter中做商务逻辑是不可取的。相反,使用一些方法来初始化你的bean,比如'f:viewAction'。 –

相关问题