程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> JSP編程 >> 關於JSP >> JSP標簽分頁實現

JSP標簽分頁實現

編輯:關於JSP

網也中經常會用到分頁,分頁的實現有很多中。從數據庫中回去分頁數據的方法一般都差不多,主要就是怎麼在網頁上呈現出來的差別。一般我們會定義一個實體類,他將存放所有與分頁相關的數據和設置。在使用struts2的時候可以在後台直接將將數據填充到分頁實體類對象中,然後可以在結果頁面通過標簽活著EL表達式來獲取相應的信息來完成分頁顯示。還有一種就是我們可以通過JSP標簽來完成分頁的顯示。

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

[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] 
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對象。

標簽類寫完了,我們還要編寫對應的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中進行注冊:

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

[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頁面中使用我們自己的標簽來完成分頁條的顯示了。

[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

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved