核心代碼
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>
~~~
結果

- 學習心得
- 將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