java对list分页
① java后台取到list结果集,现在在前台全部遍历出来,现在想进行分页如何做
分页是在后台做的
你可以用hibernate分页,也可以写一个通用的分页工具类,还可以用C标签分页,相关知识网络搜一下,一大堆的
② java 数据放在了list中,如何实现前台分页
比如你有个List list = new ArrayList();
你在页面拿到这个list集合,存在页面内存里面,通过数组下边每次取5条记录,来实现分页效果
③ java 如果所有数据是从List里取出来的 那如何进行分页
比如你有个list
list
=
new
arraylist();
你在页面拿到这个list集合,存在页面内存里面,通过数组下边每次取5条记录,来实现分页效果
④ java:想把一个集合里面的数据在页面上做成分页,求代码。这个集合里的数据不是从数据库拿到的
int cou=list.size()%pageBean.getPageSize();
int number=0;
if(pageBean.getCurrentPage()==pageBean.inits())
{
if(cou==0&&list.size()>0)
{
number=(pageBean.getCurrentPage())*pageBean.getPageSize();
}else{
number=(pageBean.getCurrentPage()-1)*pageBean.getPageSize()+cou;
}
}else
{
number=pageBean.getCurrentPage()*pageBean.getPageSize();
}
for(int i=pageBean.getPageSize()*(pageBean.getCurrentPage()-1);i<number;i++)
{
pagelist.add(list.get(i));
}
⑤ JAVA这个能分页吗 List<HashMap<String, String>> list = new ArrayList<HashMap<String, String>>();
java web分页无外乎两种,一种是直接取出来,放到一个集合里,通过传begin 和 end 参数控制分页,还有一种就是把分页工作交给数据库,让数据库读取需要的begin~end之间的数据。
JAVA分页实现代码示例:
package com.page;
public class PageUtil {
// 每页显示的条数
private int pageSize;
// 总共的条数
private int recordCount;
// 当前页面
private int currentPage;
public PageUtil(int pageSize, int recordCount, int currentPage) {
this.pageSize = pageSize;
this.recordCount = recordCount;
setCurrentPage(currentPage);
}
// 构造方法
public PageUtil(int pageSize, int recordCount) {
this(pageSize, recordCount, 1);
}
// 总页数
public int getPageCount() {
// 总条数/每页显示的条数=总页数
int size = recordCount / pageSize;
// 最后一页的条数
int mod = recordCount % pageSize;
if (mod != 0)
size++;
return recordCount == 0 ? 1 : size;
}
// 包含,起始索引为0
public int getFromIndex() {
// System.out.println("from index:"+(currentPage-1) * pageSize);
return (currentPage - 1) * pageSize;
}
// 不包含
public int getToIndex() {
// System.out.println("to index:"+Math.min(recordCount, currentPage *
// pageSize));
return Math.min(recordCount, currentPage * pageSize);
}
// 得到当前页
public int getCurrentPage() {
return currentPage;
}
// 设置当前页
public void setCurrentPage(int currentPage) {
int validPage = currentPage <= 0 ? 1 : currentPage;
validPage = validPage > getPageCount() ? getPageCount() : validPage;
this.currentPage = validPage;
}
// 得到每页显示的条数
public int getPageSize() {
return pageSize;
}
// 设置每页显示的条数
public void setPageSize(int pageSize) {
this.pageSize = pageSize;
}
// 得到总共的条数
public int getRecordCount() {
return recordCount;
}
// 设置总共的条数
public void setRecordCount(int recordCount) {
this.recordCount = recordCount;
}
}
-------------------------------------------------------------------------------------------
下面的代码是放在jsp里面的
-------------------------------------------------------------------------------------------
<%
PublishersDAO = PublishersDAO.getInstance();
List records = .getModels();
String pageStr = request.getParameter("page");
int currentPage = 1;
if (pageStr != null)
currentPage = Integer.parseInt(pageStr);
PageUtil pUtil = new PageUtil(10, records.size(), currentPage);
currentPage = pUtil.getCurrentPage();
%>
-----------下面这个是放在有变量的上面--------------------------------------------------
<%
for (int i = pUtil.getFromIndex(); i < pUtil.getToIndex(); i++) {
PublisherModel model = (PublisherModel) records.get(i);
%>
//中间是删除修改之类的代码
<%}%>
------------这个是结尾的-----------------------------------------------------------------
<tr><td width=100% bgcolor="#eeeeee" colspan=4 align="center">
记录总数<%=pUtil.getRecordCount()%>条 当前页/总页数<%=currentPage%>
/<%=pUtil.getPageCount()%>每页显示<%=pUtil.getPageSize()%>条
<a href="publishers.jsp?page=1">首页</a>
<a href="publishers.jsp?page=<%=(currentPage - 1)%>">上页</a>
<a href="publishers.jsp?page=<%=(currentPage + 1)%>">下页</a>
<a href="publishers.jsp?page=<%=pUtil.getPageCount()%>">末页</a>
</td></tr>
-------------------------------------------------------------------------------------------
⑥ java 怎么分页查询数据
分页与sql有关,前台关系不大,sql进行抽行查询,返回的list数目由sql控制,进行显示,java这面传入的sql会带参数进去,也就是sql的where条件。
⑦ java 关于分页的问题
要说分页,实现起来还是蛮简单的。说说我的理解把。分页的几个要素,每页显示的记录条数pageSize,查询出来的记录总体数list.size(),显示总页数total,返回当前页的记录getPage()。给你一个我写的简单例子。
这个暂定为Page.java类,我就写写思路,其他我就不写了
private int pageSize =3; //每页显示条数为3条
int pageNumber = 1; //默认当前页为第一页
public int getTotal() {
//获取总页数
int total =list.size()/pageSize; //这里的list就是你要查询的list记录,
int e =list.size()%pageSize;
if(e!=0)
{
total =total +1 ;
}return total;
}
//下面是获取当前页记录的方法
public List getPage (int pageNumber)
{
int total = getTotal();
List all=getList(); //获取查询出来的list总列表
int e =all.size()%pageSize;
if(e==0) e+=pageSize;
List res = new ArrayList(); //定义的res为了获取当前页的记录
if(pageNumber>=total) //如果当前页大于总页数,返回最后一条记录
{
for(int i=all.size()-e;i<(all.size());i++)
{
res.add(all.get(i));
}
}
else if(pageNumber<=1){
//如果当前页小于等于1,返回第一页的记录
for(int i=0;i<pageSize;i++){
res.add(all.get(i));
}
}
else {
//下面剩下的是常规情况,输入正常页的情况
for(int i=(pageNumber-1)*pageSize;i<pageNumber*pageSize;i++){
res.add(all.get(i));
}
}
return res; }
}
然后在jsp里定义当前页,获取总页数,获取当前页的列表。总之,分页真的不太难,你要懂得它的原理,自己写一个成功的例子ok了
刚想了想,再给说下在jsp里怎么用把,
<%
String currenP = request.getParameter("currenp"); //获取当前页的参数,因为当你点上一页,下一页的时候,currenP随着-1,或者+1.需要注意这里获取的当前页是String类型,待会需要转换成int类型
int currentpage =1 ; //默认当前页为第一页
if(currenP!=null)
{
currentpage = Integer.parseInt(currenP);
}
Page ns = new Page();
int totalpage =ns.getTotal(); //获取总页数
List list = new ArrayList(); //建立一个list对象,获取当前页的记录
list = ns.getPage(currentpage);
request.setAttribute("1ist",list);
%>
<tr > <td colspan ="5" align="center">
共有<%=totalpage %>页
<a class="pages" href ="News.jsp?currenp=1">首页</a>
<%
if(currentpage==1||currentpage-1<1)
{
out.print("上一页");
}
else{
%>
<a class="pages" href ="News.jsp?currenp=<%=currentpage-1%>">上一页</a>
<%} %>
<%
if(currentpage+1>totalpage) {
out.print("下一页");
}
else {
%>
<a class="pages" href ="News.jsp?currenp=<%=currentpage+1%>">下一页</a>
<%
}
%>
<a class="pages" href ="News.jsp?currenp=<%=totalpage%>">末页</a>
</td>
</tr>
注意一点,News.jsp是当前页的名字,当你点击上一页,下一页,首页,末页的时候,它会返回到当前页的list。不知道我说的你听懂没
⑧ java 如果所有数据是从List里取出来的 那如何进行分页
如要分页,最好使用LinkedList,这个LIST是使用链表,所以是严格的顺序的
int n = 10; //每页条数
int per = list.size()/n+(list.size%n==0?0:1) //页数
通过list.get(int index)来获取每条数据,index是序号,第一页取1-10,第二页取11-20,依次取之
⑨ java 数据放在了list中,如何实现前台分页
把list放在session里,然后计算出页码,利用页码和每页显示的数据量,控制要显示的数据,显示在页面上。