p:dataList没有更新

时间:2017-01-29 19:35:10

标签: java primefaces ejb

我有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);
    }
}

2 个答案:

答案 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一起使用的页面。