p:dataTable 不分页
p:dataTable does not paginate
我有一个分页数据table:
<h:form>
<p:dataTable var="proj" value="#{orderListView.projects}"
paginator="true" rows="3"
paginatorTemplate="{RowsPerPageDropdown} {FirstPageLink} {PreviousPageLink} {CurrentPageReport} {NextPageLink} {LastPageLink}"
>
<p:column sortBy="#{proj.id}">
<h:outputText value="#{proj.id}" />
</p:column>
<p:column sortBy="#{proj.name}">
<h:outputText value="#{proj.name}" />
</p:column>
<p:column sortBy="#{proj.displayName}">
<h:outputText value="#{proj.displayName}" />
</p:column>
</p:dataTable>
</h:form>
基于此实体:
@Entity
public class Project implements Serializable {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private int id;
private String displayName;
private String name;
public Project() {}
public Project(int id, String displayName, String name) {
this.id = id;
this.displayName = displayName;
this.name = name;
}
// Getters+setters.
}
并填充在这个 bean 中(为简洁起见,我省略了 DAO/Service 部分,我在 @PostConstruct
中对模型进行硬编码):
@ManagedBean
@RequestScoped
public class OrderListView {
private List<Project> projects;
@PostConstruct
public void init() {
projects = new ArrayList<Project>();
projects.add(new Project(10, "Cruze", "cruze"));
projects.add(new Project(11, "Dark-Hive", "dark-hive"));
projects.add(new Project(12, "Delta", "delta"));
projects.add(new Project(10, "Cruze", "cruze"));
projects.add(new Project(11, "Dark-Hive", "dark-hive"));
projects.add(new Project(12, "Delta", "delta"));
projects.add(new Project(13, "Dot-Luv", "dot-luv"));
projects.add(new Project(14, "Eggplant", "eggplant"));
projects.add(new Project(15, "Excite-Bike", "excite-bike"));
projects.add(new Project(16, "Flick", "flick"));
projects.add(new Project(17, "Glass-X", "glass-x"));
projects.add(new Project(18, "Cruze", "cruze"));
projects.add(new Project(19, "Dark-Hive", "dark-hive"));
projects.add(new Project(20, "Delta", "delta"));
projects.add(new Project(23, "Dot-Luv", "dot-luv"));
projects.add(new Project(24, "Eggplant", "eggplant"));
projects.add(new Project(25, "Excite-Bike", "excite-bike"));
projects.add(new Project(26, "Flick", "flick"));
projects.add(new Project(27, "Glass-X", "glass-x"));
}
public List<Project> getProjects() {
return projects;
}
}
数据table 正确显示了列表,但分页不起作用。这是怎么引起的,我该如何解决?我也试过懒加载,还是不行
我不确定你这边出了什么问题,但我将你的代码复制到一个测试项目中,分页器在 PrimeFaces 5.2 上工作得很好。
我有一个分页数据table:
<h:form>
<p:dataTable var="proj" value="#{orderListView.projects}"
paginator="true" rows="3"
paginatorTemplate="{RowsPerPageDropdown} {FirstPageLink} {PreviousPageLink} {CurrentPageReport} {NextPageLink} {LastPageLink}"
>
<p:column sortBy="#{proj.id}">
<h:outputText value="#{proj.id}" />
</p:column>
<p:column sortBy="#{proj.name}">
<h:outputText value="#{proj.name}" />
</p:column>
<p:column sortBy="#{proj.displayName}">
<h:outputText value="#{proj.displayName}" />
</p:column>
</p:dataTable>
</h:form>
基于此实体:
@Entity
public class Project implements Serializable {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private int id;
private String displayName;
private String name;
public Project() {}
public Project(int id, String displayName, String name) {
this.id = id;
this.displayName = displayName;
this.name = name;
}
// Getters+setters.
}
并填充在这个 bean 中(为简洁起见,我省略了 DAO/Service 部分,我在 @PostConstruct
中对模型进行硬编码):
@ManagedBean
@RequestScoped
public class OrderListView {
private List<Project> projects;
@PostConstruct
public void init() {
projects = new ArrayList<Project>();
projects.add(new Project(10, "Cruze", "cruze"));
projects.add(new Project(11, "Dark-Hive", "dark-hive"));
projects.add(new Project(12, "Delta", "delta"));
projects.add(new Project(10, "Cruze", "cruze"));
projects.add(new Project(11, "Dark-Hive", "dark-hive"));
projects.add(new Project(12, "Delta", "delta"));
projects.add(new Project(13, "Dot-Luv", "dot-luv"));
projects.add(new Project(14, "Eggplant", "eggplant"));
projects.add(new Project(15, "Excite-Bike", "excite-bike"));
projects.add(new Project(16, "Flick", "flick"));
projects.add(new Project(17, "Glass-X", "glass-x"));
projects.add(new Project(18, "Cruze", "cruze"));
projects.add(new Project(19, "Dark-Hive", "dark-hive"));
projects.add(new Project(20, "Delta", "delta"));
projects.add(new Project(23, "Dot-Luv", "dot-luv"));
projects.add(new Project(24, "Eggplant", "eggplant"));
projects.add(new Project(25, "Excite-Bike", "excite-bike"));
projects.add(new Project(26, "Flick", "flick"));
projects.add(new Project(27, "Glass-X", "glass-x"));
}
public List<Project> getProjects() {
return projects;
}
}
数据table 正确显示了列表,但分页不起作用。这是怎么引起的,我该如何解决?我也试过懒加载,还是不行
我不确定你这边出了什么问题,但我将你的代码复制到一个测试项目中,分页器在 PrimeFaces 5.2 上工作得很好。