JAVA这个能分页吗? List<HashMap<String, String>> list = new ArrayList<HashMap<String, String>>();

publicList<HashMap<String,String>>getAllInfo(){List<HashMap<String,String>>list=newAr... public List<HashMap<String, String>> getAllInfo() {
List<HashMap<String, String>> list = new ArrayList<HashMap<String, String>>();

arrayList.clear();
brrayList.clear();
crrayList.clear();

crrayList = Soap.GetWebServre("selectAllCargoInfor", arrayList, brrayList);
HashMap<String, String> tempHash = new HashMap<String, String>();
tempHash.put("1", "1");
tempHash.put("2", "2");
tempHash.put("3", "3");
tempHash.put("4", "4");
tempHash.put("5", "5");
tempHash.put("6", "7");

list.add(tempHash);

for (int j = 0; j < crrayList.size(); j += 6) {
HashMap<String, String> hashMap = new HashMap<String, String>();
hashMap.put("", crrayList.get(j));
hashMap.put("1", crrayList.get(j + 1));
hashMap.put("2", crrayList.get(j + 2));
hashMap.put("3", crrayList.get(j + 3));
hashMap.put("4", crrayList.get(j + 4));
hashMap.put("5", crrayList.get(j + 5));
list.add(hashMap);
}

return list;
}
数据放list里怎么进行分页操作。
展开
 我来答
nanwang21
推荐于2016-02-11 · TA获得超过2943个赞
知道大有可为答主
回答量:1220
采纳率:82%
帮助的人:243万
展开全部
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 dao = PublishersDAO.getInstance();
List records = dao.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>
-------------------------------------------------------------------------------------------
匿名用户
2014-03-21
展开全部
这个方法非要一次全部返回吗。
Soap.GetWebServre("selectAllCargoInfor", arrayList, brrayList);

如果这个方法不分页,那在本地分页,是没多大意义的。

for (int j = 0; j < crrayList.size(); j += 6) {
这里可以分页,但已经是客户端了
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名用户
2014-03-21
展开全部
楼上回答正确,如果非要分页
/**
原始数据,一页行数,页码

*/

public List getPage(List list,int onePageLine,int pageNum){
if(list!=null&&list.size()>=onePageLine*pageNum){
return list.subList(onePageLine*(pageNum-1),onePageLine*pageNum);
}
return null;

}

请关注www.highersoft.net
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
卖贫道的小火柴
推荐于2016-05-12 · TA获得超过229个赞
知道小有建树答主
回答量:253
采纳率:0%
帮助的人:250万
展开全部

(1) .数据放在List中是可以实现分页的,基本原理是因为List集合是有序的。

需要定义一下几个参数:

  1. int pagerSize;  每一页展示的条数

  2. int currentPageIndex;  当前页的序号

  3. int startRowIndex;  查询记录的起始下标

  4. int totalPage;  list中的记录能被分成的总页数

(2). totalPage = list.size() % pagerSize == 0 ? list.size()/pagerSize : (list.size() / pagerSize + 1);

       startRowIndex = (currentPageIndex - 1) * pagerSize;

(3).重新定义一个List集合存放分页出来的数据

     LIst<Map<String,String>> divideMap = new .....;

     for (int i = startRowIndex; i < startRowIndex + pagerSize; i++)

    {

        divideMap.add(list.get(i));

    }

本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式