Val*_*lla 6 jsf primefaces jsf-2
我试图使用主要面孔的功能,允许用户编辑表格本身的行数据.我已经按照这个链接来实现它:
http://www.primefaces.org/showcase/ui/datatableRowEditing.jsf
当我说编辑用户时,输入的新值不会发送到bean.它仍然只显示旧值.
我在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>
Run Code Online (Sandbox Code Playgroud)
我在bean中的代码:
public String onEdit(RowEditEvent event) {
User user=(User)event.getObject());
user.getFirstName();
}
Run Code Online (Sandbox Code Playgroud)
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;
}
Run Code Online (Sandbox Code Playgroud)
我已经尝试了一些帖子中给出的建议,但是它们没有用.可以有人让我知道如何获得新值.我使用的是glassfish 4.0,primefaces 3.5.
我能够找出问题.每次当我在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;
}
Run Code Online (Sandbox Code Playgroud)
所以getUsersList是我在p:datatable中的var的值,现在当我调用onEdit时,它会检查列表,如果它为null,它会进行数据库调用或不调用数据库.
| 归档时间: |
|
| 查看次数: |
6026 次 |
| 最近记录: |