Repeater 实现分页

参考:http://blog.sina.com.cn/s/blog_78046c640100ukqi.html

 

Repeater

轻量级,完全的自定义

Repeater分页,需要依靠PagedDataSource。这个类存在于System.Web.UI.WebControls命名空间。它的作用是作为数据源与数据显示控件的中间介质。如:

  数据源->PagedDataSource->数据绑定控件

 

之间的关系通过以下代码来实现:

  PagedDataSource pds=new PagedDataSource ();

  pds.DataSource=dataTable;

  repeater1.DataSource=pds;

  repeater1.DataBind();

  三者之间发生关系的代码就是这些。

  那么PagedDataSource又是怎样工作的呢?MSDN上面也没有讲。这仅仅是我的推断。

  PagedDataSource封装了从底层数据源(如:DataTable)中取出第几页数据的中间过程。我们只需设置

  PagedDataSource .AllowPaging=true;

  PagedDataSource .PageSize=xx;

  PagedDataSource.CurrentPageIndex=currentPage;

  就可以取出指定页的数据,而数据绑定控件将从PagedDataSource 中获取这些数据以显示。PagedDataSource 在这里成一个中介。而数据绑定组件如何取数据,PagedDataSource 是如何分页,并取出对应的数据,这个是asp.net框架内部实现,对我们完全透明。

  另一个需要着重讲的是,PagedDataSource 中页号是从0开始的,并不是从1开始。

 

 

using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using Buddha.Utils;
using System.Data.Common;


public partial class Repeater : System.Web.UI.Page
{


    protected void Page_Load(object sender, EventArgs e)
    {
        PagedDataSource pds = new PagedDataSource();
        pds.DataSource = CreateDataSource().DefaultView;

        //pds.AllowCustomPaging = true;
        pds.AllowPaging = true;
        //pds.AllowServerPaging = true;
        pds.PageSize = 3;

        int currentPage=Convert.ToInt32(Request["page"]);

        //设当前页
        pds.CurrentPageIndex = currentPage;

        //设几个超链接
        if (!pds.IsFirstPage)
        {
            lnkUp.NavigateUrl = Request.CurrentExecutionFilePath + "?page=" + (currentPage - 1);
        }

        if (!pds.IsLastPage)
        {
            lnkDown.NavigateUrl = Request.CurrentExecutionFilePath + "?page=" + (currentPage + 1);
        }


        lbl_info.Text = "" + (currentPage+1) + "页、共" + pds.PageCount + "";

        Repeater1.DataSource = pds;
        Repeater1.DataBind();


    }


    /// <summary>
    /// 创建数据源
    /// </summary>
    /// <returns></returns>
    private DataTable CreateDataSource()
    {
        DataBase db = AppCommon.DefaultDataBase;
        DataTable dt = db.GetDataTable("select id,txt2,txt3,txt4,txt5,txt6 from tbmain1");

        db.Dispose();
        return dt;
    }

 

  aspx中的代码如下:

<%@ Page Language="C#" CodeFile="Repeater.aspx.cs" Inherits="Repeater" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
    <title>Repeater实验室</title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <asp:HyperLink ID="lnkUp" runat="server">上一页</asp:HyperLink>
        <asp:HyperLink ID="lnkDown" runat="server">下一页</asp:HyperLink>
        <asp:Label ID="lbl_info" runat="server" Text="当前第x页,共x页"></asp:Label><br />
        <table>      
            <asp:Repeater ID="Repeater1" runat="server">
                <ItemTemplate>
                    <tr><td>项目名称:</td><td><%# eval_r("txt2") %></td></tr>
                    <tr><td>承担单位:</td><td><%# eval_r("txt3") %></td></tr>
                    <tr><td>计划类别:</td><td><%# eval_r("txt4") %></td></tr>
                    <tr><td>技术领域:</td><td><%# eval_r("txt5") %></td></tr>
                    <tr><td colspan="2"><hr /></td></tr>
                </ItemTemplate>
            </asp:Repeater>
        </table>
    </div>
    </form>
</body>
</html>
posted @ 2012-04-30 01:31  zwein  Views(685)  Comments(1)    收藏  举报