核心代码
web
~~~
//分页查询
public void queryCategoryList(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// 1 调用service中的查询方法
try {
String tmp=request.getParameter("currentPage");
String tmp1=request.getParameter("currentCount");
int currentPage = Integer.parseInt(tmp);//当前页
int currentCount = Integer.parseInt(tmp1);//当前总数
//没参数设置为第一页
// 给分页数据设置默认值
if (currentCount==0){
currentCount=5;
}
if (currentPage==0){
currentPage=1;
}
CategoryService service=new CategoryService();
Page page = service.findPageCategory(currentPage, currentCount);
if (page!=null) {
request.setAttribute("page",page);
request.getRequestDispatcher("/category-list.jsp").forward(request,response);
} else {
request.getRequestDispatcher("/category-list.jsp").forward(request,response);
}
} catch (SQLException e) {
e.printStackTrace();
}
}
~~~
service
~~~
//分页查询
public Page findPageCategory(int currentPage, int currentCount) throws SQLException {
Page page=new Page();
// 1 查询出生鲜数据的总数
CategoryDao dao = new CategoryDao();
int totalCount = dao.queryCount();
/* 总数 每页显示数目 总页数
9 10 0.9 1
10 10 1 1
11 10 1.1 2
java ceil
*/
// 2 根据总数和当前页显示数 计算出总页数
int totalPage= (int) Math.ceil(1.0*totalCount/currentCount);
//3 将分页相关信息封装到page类中
page.setCurrentCount(currentCount);
page.setCurrentPage(currentPage);
page.setTotalCount(totalCount);
page.setTotalPage(totalPage);
// 计算查询的起始位置
// 页数 每页显示条数 起始位置
//
// 1 3 0
// 2 3 3
// 3 3 6 (currentPage-1)*currentCount
//计算出起始位置
int startPosition=(currentPage-1)*currentCount;
// 分页查询数据
List<Category> categories = dao.queryPageCategoryList(startPosition,currentCount);
// 将集合数据封装到page类中
page.setList(categories);
return page;
}
~~~
dao
~~~
//分页查询
public List<Category> queryPageCategoryList(int startPosition, int currentCount) throws SQLException {
ComboPooledDataSource dataSource=new ComboPooledDataSource();
QueryRunner queryRunner=new QueryRunner(dataSource);
String sql="select * from category limit ?,?";
List<Category> categoryList = queryRunner.query(sql, new BeanListHandler<Category>(Category.class),startPosition,currentCount);
return categoryList;
}
~~~
前端
~~~
<!--分页 -->
<nav>
<ul class="pagination pull-right">
<li class="previous"><a href="#">«</a></li>
<c:forEach begin="1" end="${page.totalPage}" var="Page">
<li><a href="${pageContext.request.contextPath}/category?method=queryCategoryList¤tPage=${Page}¤tCount=5">${Page}</a></li>
</c:forEach>
<li><a href="#">»</a></li>
</ul>
</nav>
~~~
结果
![](https://box.kancloud.cn/ef77b59ee9769793598a25e60f87a1d8_1585x814.png)
- 学习心得
- 将jar包加入项目中
- Servlet
- 编写第一个Servlet
- 使用Servlet3.0创建Servlet
- HttpServletRequest简介-获取请求行和请求头
- HttpServletResponse获取请求参数
- response对象发送响应行和响应头
- HttpServletResponse发送请求体
- 【实例】验证码
- Servlet的生命周期
- ServletConfig对象
- ServletContext-获取项目初始化参数
- ServletContext对象-在多个Servlet之间共享参数
- 请求转发
- 【实例】登录错误时显示错误界面
- 重定向介绍
- 网页的自动刷新
- Servlet线程安全
- 案例 文件下载
- Cookie与Session会话技术
- 会话技术概述
- Cookie的会话流程
- 获取Cookie
- 【案例 】记录网站上一次访问时间
- Session的会话流程
- 使用Session域对象存取数据
- Session的生命周期和持久化
- 【实例】购物车的简单使用
- JSP技术
- JSP指令
- JSP隐式对象
- JSP标签
- JSTL标签库
- EL表达式
- EL的内置对象和执行表达式
- JSTL简介
- JSTL-if标签
- JSTL-forEach标签
- 【案例】实现商品列表展示
- MySQL数据库
- SQL语句
- 命名规则与数据类型
- SQL-增删改查
- 设计数据库
- JDBC的应用
- JDBC连接数据库
- 查询
- 插入.删除.修改
- Junit单元测试
- 预防SQL注入
- JDBCutils工具类
- 监听器Listener
- ServletContextListener
- HttpSessionListener和ServletRequestListener
- 域对象属性监听器
- 对象感知监听器
- 【案例】商品促销活动推广
- 过滤器Filter
- 创建一个过滤器
- Filter生命周期和配置
- 【案例】解决中文输出乱码问题
- XML入门
- XML元素和解析方式
- XML约束
- 实战-生鲜后台管理系统
- MVC和三层架构
- 项目需求和项目搭建
- 数据库设计
- 注册功能
- 登录功能
- 记住密码
- BeanUtils的使用
- Servlet的抽取(上)
- Servlet的抽取(下)
- 增加生鲜种类
- 查询生鲜列表
- 分页功能
- 修改生鲜信息
- 删除生鲜功能
- 权限控制Filter