我有p:datalist
,其中包含一组对象和p:commandButton
,它们应该向此集添加一个对象。但无论我做什么,datalist
都会很快更新,并且不包含新对象。但是当我单击2次时,datalist
刷新2次,并且在第一次刷新后它不包含任何新元素,但是在添加第2个第一个元素之后。如何同步此更新?我尝试了update="id"/"@all"
,同步/异步,ajax,但它总是一样的。
页
<m:form id="lastForm">
<p:commandButton id="addProject" action="#{userBacking.addProject}" value="myadd">
</p:commandButton>
<p:dataList id="mydatalist" value="#{userBacking.user.projects.toArray()}" var="project">
#{project.projectName}, #{project.id}
</p:dataList>
</m:form>
UserBacking类
@Named
@RequestScoped
public class UserBacking {
private User user;
@Inject
private UserService userService;
(...)
public void addProject() {
userService.addProject(user);
}
}
UserService
@Stateless
public class UserService extends BaseEntityService<Long, User> {
@PersistenceContext
private EntityManager entityManager;
(...)
public void addProject(User user) {
User existingUser = get(user);
Project proj = new Project();
proj.setProjectName("projectname");
proj.setUser(existingUser);
existingUser.addProjects(proj);
super.update(existingUser);
}
}
答案 0 :(得分:1)
我会说你需要在命令按钮中actionListener
而不是action
(除了你的例子中缺少的更新属性,尽管你说你正在使用它)。在发送给服务器的正常POST同步请求期间,action
占有一席之地。
此外,我的项目中的一般做法是,当在某个页面中使用ajax处理时,我们使用了@ViewScoped
个bean而不是RequestScoped
个。
答案 1 :(得分:0)
尝试将update="mydatalist"
属性添加到<p:commandButton ... />
。在您的支持bean中也使用@ViewScoped
而不是@RequestScoped
。每次请求都会创建一个RequestScoped bean,因此会丢失先前存储的数据。只有在根元素更改即UIViewRoot
时,才会清除并重新创建ViewScoped bean。 @ViewScoped
支持bean应足以管理与ajax一起使用的页面。