JSP標籤分頁實現

網也中常常會用到分頁,分頁的實現有不少中。從數據庫中回去分頁數據的方法通常都差很少,主要就是怎麼在網頁上呈現出來的差異。通常咱們會定義一個實體類,他將存放全部與分頁相關的數據和設置。在使用struts2的時候能夠在後臺直接將將數據填充到分頁實體類對象中,而後能夠在結果頁面經過標籤活着EL表達式來獲取相應的信息來完成分頁顯示。還有一種就是咱們能夠經過JSP標籤來完成分頁的顯示。css

首先咱們定義一個實體類,他包含一些設置信息和承載咱們要顯示的分頁數據。html

[java] 
public class PageBean { 
     
    private int pageSize;//每頁大小 
    private int totalrows;//總記錄數 
    private int pageNum;//總頁數 
    private int curPage;//當前頁碼 
     
    private List items;//存放數據 
     
    //默認構造器,初始化成員變量 
    public PageBean(int totalRows, int curPage,List items){ 
        this.pageSize = 10; 
        this.totalrows = totalRows; 
        this.curPage = curPage; 
        this.pageNum = (int) Math.ceil((double)totalRows / pageSize); 
        this.items = items; 
    } 
 
    //省略get/set方法 

而後咱們就開始編寫咱們的分頁標籤。咱們定義一個類,讓他繼承TagSupport類,而後重寫其中的部分方法就能夠了:java

[java] 
public class PagerTag extends TagSupport { 
 
    private String value = "pb";// 存放數據實體的名字 
 
    public void setValue(String value) { 
        this.value = value; 
    } 
 
    @Override 
    public int doStartTag() throws JspException { 
        JspWriter out = pageContext.getOut(); 
        String outStr = makeString(); 
        try { 
            out.write(outStr); 
        } catch (IOException e) { 
            e.printStackTrace(); 
        } 
 
        return SKIP_BODY; 
    } 
     
    private String makeString() { 
 
        // 獲取到存放在request中的數據實體 
        Object p = pageContext.getRequest().getAttribute( 
                value); 
        PageBean pageBean = (PageBean) pageContext.getRequest().getAttribute(value); 
         
        StringBuffer sb = new StringBuffer(); 
         
        if (pageBean != null && pageBean.getItems() != null 
                && pageBean.getItems().size() > 0) { 
 
            sb.append("共" + pageBean.getCurPage() + " / " 
                    + pageBean.getPageNum() + "頁"); 
            //首頁 上一頁 
            if (pageBean.getCurPage() > 1) { 
                sb.append("<a href='?page=1'>首頁</a>"); 
                sb.append("<a href='?page=" + (pageBean.getCurPage()-1) + "'>上一頁</a>"); 
            } 
             
            //循環顯示中間頁碼,這裏也可控制最大隻顯示多少頁碼 
            for (int i = 1; i < pageBean.getPageNum() + 1; i++) { 
 
                if (i == pageBean.getCurPage()) { 
                    sb.append(" " + i + " "); 
                } else { 
                    sb.append("<a href='?page=" + i + "'> " + i + " </a>"); 
                } 
            } 
             
            //下一頁 末頁 
            if(pageBean.getCurPage() != pageBean.getPageNum()){ 
                sb.append("<a href='?page=" + (pageBean.getCurPage() + 1) + "'>下一頁</a>"); 
                sb.append("<a href='?page=" + pageBean.getPageNum() + "'>末頁</a>"); 
            } 
 
        } 
         
        return sb.toString(); 
    } 
 

咱們這裏經過在value屬性來從Requst中獲取以前咱們從後臺填充了數據的PageBean對象。web

標籤類寫完了,咱們還要編寫對應的tlg文件:數據庫

[html] 
<?xml version="1.0" encoding="UTF-8"?> 
<!DOCTYPE taglib PUBLIC "-//Sun Microsystems, Inc.//DTD JSP Tag Library 1.1//EN" "http://java.sun.com/j2ee/dtds/web-jsptaglibrary_1_1.dtd"> 
<taglib> 
    <tlibversion>1.2</tlibversion> 
    <jspversion>1.1</jspversion> 
    <shortname>page</shortname> 
    <uri>/luo_pager</uri> 
    <tag> 
        <name>pager</name> 
        <tagclass>com.luojing.pager.PagerTag</tagclass> 
        <bodycontent>empty</bodycontent> 
        <attribute> 
            <name>value</name> 
            <required>true</required> 
            <rtexprvalue>false</rtexprvalue> 
        </attribute> 
    </tag> 
</taglib> 
而後在web.xml中進行註冊:app

[html]
<jsp-config> 
        <taglib> 
            <taglib-uri>/luo_pager</taglib-uri> 
            <taglib-location>/WEB-INF/page_taglib.tld</taglib-location> 
        </taglib> 
    </jsp-config> 
咱們再編寫一個測試用的Servlet:jsp

[java]
public class PagerServlet extends HttpServlet { 
 
    @Override 
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) 
            throws ServletException, IOException { 
 
        int curPage = Integer.parseInt(req.getParameter("page") == null ? "1" 
                : req.getParameter("page")); 
        List list = new ArrayList(); 
         
        int start = (curPage -1)* 10 + 1; 
        int end = start + 10 > 26 ? 26 : start + 10; 
        for(int i = start; i < end; i++){ 
            list.add(i); 
        } 
 
        PageBean pageBean = new PageBean(25, curPage, list); 
        req.setAttribute("pb", pageBean); 
         
         
        RequestDispatcher rd = req.getRequestDispatcher("index.jsp"); 
        rd.forward(req,resp); 
    } 

這樣咱們就能夠在咱們的JSP頁面中使用咱們本身的標籤來完成分頁條的顯示了。ide

[html] 
<%@ page language="java" import="java.util.*,com.luojing.pager.*" pageEncoding="UTF-8"%> 
<%@ taglib prefix="luo" uri="/luo_pager" %> 
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> 
<html> 
  <head> 
    <title>pager test</title> 
  </head> 
   
  <body> 
    <% 
        PageBean p = (PageBean) request.getAttribute("pb"); 
        List<Integer> list = p.getItems(); 
        for(Integer i : list){ 
            pageContext.getOut().write("值爲: " + i + "<br/>"); 
        } 
     
    %> 
    <luo:pager value="pb"/> 
  </body> 
</html> 
這裏爲了方便,我直接在JSP頁面中循環輸出PageBean對象中攜帶的數據。學習

效果以下:測試

\時間匆忙,頁面效果作的比較醜陋,不過所須要的功能基本都可以實現。若是頁面還須要傳遞其餘參數,那麼最好將page參數(指定要顯示的頁碼)放在查詢字符串的最後,這樣能夠在分頁的時候保留其餘的參數。之前我作分頁沒用過使用JSP標籤,對JSP標籤也不是很熟悉,今天就當學習一下JSP自定標籤吧。做者:jdluojing

相關文章
相關標籤/搜索