本人采用的是三层架构写的一个比较简单的Servlet类实现分页的功能。
Servlet类中的代码:
package com.fruit.servlet;
import java.io.IOException;
import java.util.ArrayList;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import com.fruit.Factory.BasicFactory;
import com.fruit.pojo.Goods;
@WebServlet(name="GoodsList",urlPatterns="/GoodsList")
public class GoodsList extends HttpServlet{
protected void doGet(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
doPost(req, resp);
}
protected void doPost(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
req.setCharacterEncoding("utf-8");
ArrayList<Goods> list;
try {
String tj = "1=1";//总记录条数
int pageNum = 3;//每页显示的条数
String emPage = req.getParameter("currpage");//获取第几页
int currpage = 1;//标识(当前页)
if(emPage==null){
currpage=1;
}else{
currpage=Integer.parseInt(emPage);
}
list = BasicFactory.getGoodsPA().seletGoods(currpage, pageNum, tj);
int n=BasicFactory.getGoodsPA().getCountPage(pageNum, tj);//总页数
req.setAttribute("list", list);
req.setAttribute("n", n);
req.setAttribute("currpage", currpage);//当前页
req.setAttribute("totalCount",list.size());//总记录条数
req.getRequestDispatcher("list.jsp").forward(req, resp);
} catch (Exception e) {
e.printStackTrace();
}
}
}
jsp中的页面代码:
<form action="GoodsList">
<table border="1">
<tr>
<th>商品图片</th>
<th>商品名称</th>
<th>商品类型</th>
<th>商品数量</th>
</tr>
<c:forEach items="${requestScope.list }" var="goods">
<tr>
<td><img alt="" src="${goods.imgurl }" style="width:80px;height:80px"></td>
<td>${goods.goods_name }</td>
<td>${goods.goods_type }</td>
<td>${goods.pnum }</td>
</tr>
</c:forEach>
<tr>
<td colspan="4">
当前${currpage }页/${n}页
<a href="GoodsList?currpage=1">首页</a>
<a href="GoodsList?currpage=${currpage-1<=1?1:currpage-1}">上一页</a>
<a href="GoodsList?currpage=${currpage+1>n?n:currpage+1}">下一页</a>
<a href="GoodsList?currpage=${n}">尾页</a>
跳转到
<input type="number" min="1" max="${n}" name="currpage" style="width:50px" value="${currpage }"/>
/${n }页
<input type="submit" value="GO">
</td>
</tr>
</table>
</form>
效果展示: