這次主要是講解一下通過登錄後對得到的數據進行分頁,首先我們新建一個登錄頁面login.jsp,因為我們主要學習一下分頁,所以登錄驗證的部分不再闡述,主要代碼如下:
1 <form action="pageServlet"> 2 用戶名:<input type="text" name="username"><br> 3 密 碼:<input type="text" name="password"><br> 4 <input type="submit" value="提交"> 5 </form>
首先建立實體類User.java並添加get和set方法:
1 public class User { 2 private String username; 3 private String password; 4 public String getUsername() { 5 return username; 6 } 7 public void setUsername(String username) { 8 this.username = username; 9 } 10 public String getPassword() { 11 return password; 12 } 13 public void setPassword(String password) { 14 this.password = password; 15 } 16 17 }
我們可以看到form表單是提交到pageServlet中,所以我們新建一個PageServlet,並在Servlet中獲取到數據,同時做一些分頁的准備,具體含義可以參照注釋理解,PageServlet代碼:
1 public class PageServlet extends HttpServlet { 2 public void doGet(HttpServletRequest request, HttpServletResponse response) 3 throws ServletException, IOException { 4 List<User> list = new ArrayList<User>(); 5 // 在這裡我不再連接數據庫而是用虛擬的數據進行測試效果,小伙伴可以連接數據庫查詢到之後返回一個list 6 for (int i = 1; i < 7; i++) { 7 User user1 = new User(); 8 user1.setUsername("第" + i + "個用戶名"); 9 user1.setPassword("第" + i + "密碼"); 10 list.add(user1); 11 } 12 HttpSession session = request.getSession(); 13 // 將數據存到session中以便於在前台獲取 14 session.setAttribute("userList", list); 15 //獲取當前頁的頁數並轉為int類型,最終將數據存到session中 16 int pageNos; 17 if (request.getParameter("pageNos") == null 18 || Integer.parseInt(request.getParameter("pageNos")) < 1) { 19 pageNos = 1; 20 } else { 21 pageNos = Integer.parseInt(request.getParameter("pageNos")); 22 } 23 session.setAttribute("pageNos", pageNos); 24 // 定義總頁數並存到session中 25 int countPage = 3; 26 // 在實際開發中我們的總頁數可以根據sql語句得到查詢到的總條數,然後用總條數除每頁的條數得到總頁數 27 session.setAttribute("countPage", countPage); 28 request.getRequestDispatcher("index.jsp").forward(request, response); 29 } 30 31 public void doPost(HttpServletRequest request, HttpServletResponse response) 32 throws ServletException, IOException { 33 34 } 35 36 }
在上述代碼中我們最終將轉發到index.jsp頁面,此時我們所有的數據都將顯示在index.jsp中,用JSTL和EL表達式獲取得到,index.jsp主要代碼如下:
1 <body> 2 <c:forEach items="${userList}" var="user" begin="${(pageNos-1)*2 }" 3 end="${pageNos*2-1}"> 4 <center> 5 <div>${user.username}</div> 6 </center> 7 <center> 8 <div>${user.password}</div> 9 </center> 10 </c:forEach> 11 <center> 12 <c:if test="${pageNos>1 }"> 13 <a href="pageServlet?pageNos=1" >首頁</a> 14 <a href="pageServlet?pageNos=${pageNos-1 }">上一頁</a> 15 </c:if> 16 <c:if test="${pageNos <countPage }"> 17 <a href="pageServlet?pageNos=${pageNos+1 }">下一頁</a> 18 <a href="pageServlet?pageNos=${countPage }">末頁</a> 19 </c:if> 20 </center> 21 <form action="pageServlet"> 22 <h4 align="center">共${countPage}頁 23 <input type="text" value="${pageNos}" name="pageNos" size="1">頁 24 <input type="submit" value="go"> 25 </h4> 26 </form> 27 </body>
第二行中我們用<c:forEach >對session.setAttribute();中的內容進行獲取。注意,這裡我默認是每頁兩條數據,所以是(pageNos-1)*2,如果每頁N條數據則需將2改為N,當然N也可以從後台Servlet中獲取得到。
同時,因為我們在index.jsp中用了JSTL表達式,所以記得要導入引用:
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
到這裡我們就完成了一個簡單的分頁,快去試試吧。