zoukankan      html  css  js  c++  java
  • DataList分页方法详解

    我的DataList分页方法的核心原理是利用PagedDataSource对象,PagedDataSource类封装了DataGrid 控件的属性,这些属性使 DataGrid 可以执行分页,下面是PagedDataSource的公共属性:

    AllowCustomPaging 获取或设置指示是否启用自定义分页的值。
    AllowPaging 获取或设置指示是否启用分页的值。
    Count 获取要从数据源使用的项数。
    CurrentPageIndex 获取或设置当前页的索引。
    DataSource 获取或设置数据源。
    DataSourceCount 获取数据源中的项数。
    FirstIndexInPage 获取页中的第一个索引。
    IsCustomPagingEnabled 获取一个值,该值指示是否启用自定义分页。
    IsFirstPage 获取一个值,该值指示当前页是否是首页。
    IsLastPage 获取一个值,该值指示当前页是否是最后一页。
    IsPagingEnabled 获取一个值,该值指示是否启用分页。
    IsReadOnly 获取一个值,该值指示数据源是否是只读的。
    IsSynchronized 获取一个值,该值指示是否同步对数据源的访问(线程安全)。
    PageCount 获取显示数据源中的所有项所需要的总页数。
    PageSize 获取或设置要在单页上显示的项数。
    VirtualCount 获取或设置在使用自定义分页时数据源中的实际项数。

    第一步,取出数据到datatable中,然后获得dataview,付给PagedDataSource对象

    DataView objView = objTable.DefaultView;
    PagedDataSource objPds = new PagedDataSource();
    objPds.DataSource = objView;

    第二步,PagedDataSource对象objPds的设置

    objPds.AllowPaging = true;
    objPds.PageSize = 4;
    objPds.CurrentPageIndex = int.Parse(ViewState["pageindex"].ToString());

    上面的这两段代码都是写在BindData()函数中的,供每次点击分页按钮时调用。BindData()函数如下:                       

    private void BindData()
    {
    Books book = new Books();  //Books是我一个操作数据库表的类
    DataTable objTable = book.GetNewBooks(24);//book有个函数,返回结果是DataTable类型,大家根据自己的情况修改此处代码就行了。
    if (objTable != null && objTable.Rows.Count > 0)
    {
    DataView objView = objTable.DefaultView;
    PagedDataSource objPds = new PagedDataSource();
    objPds.DataSource = objView;

    objPds.AllowPaging = true;
    objPds.PageSize = 4;
    objPds.CurrentPageIndex = int.Parse(ViewState["pageindex"].ToString());

    if (!objPds.IsFirstPage)
    {
    lkPre.Visible = true;
    }
    else
    {
    lkPre.Visible = false;
    }

    if (!objPds.IsLastPage)
    {
    lkNext.Visible = true;
    }
    else
    {
    lkNext.Visible = false;
    }

    dlData.DataSource = objPds;
    dlData.DataBind();
    }
    }

    上面的第三行代码中的 ViewState["pageindex"] 是用来控制PagedDataSource的当前页的,我们在Page_Load事件中和第三步将要将的函数中来具体讲解如何利用 ViewState["pageindex"]控制当前页。

    第三步,分页控制

    第二步中说过利用 ViewState["pageindex"] 来控制当前页,为了在页面加载的时候就显示第一页,我们当然要在Page_load事件中将 ViewState["pageindex"]置为0。

    protected void Page_Load(object sender, EventArgs e)
    {
    if (!IsPostBack)
    {
    ViewState["pageindex"] = "0";
    BindData(); }
    }

    我们需要加两个linkbutton按钮(Previous、Next)来点击进行分页控制。

    <asp:DataList ID="dlData" runat="server" RepeatColumns="4" >
    <ItemTemplate>
    <asp:Label ID="lblName" runat="server" /><br />
    <asp:Label ID="lblTime" runat="server" />
    </ItemTemplate>
    </asp:DataList>
    <asp:linkbutton ID="lkPre" OnCommand="IndexChanging" CommandArgument="pre" runat="server" >PREVIOUS PAGE></asp:linkbutton>
    <asp:linkbutton ID="lkNext" OnCommand="IndexChanging" CommandArgument="next" runat="server" >NEXT PAGE</asp:linkbutton>

    两个按钮的 OnCommand都是IndexChanging()函数,我们通过CommandArgument(pre和next)来区分到底是向前翻还是向后翻。下面是IndexChanging()函数

    protected void IndexChanging(object sender, EventArgs e)
    {
    string strCommand = ((LinkButton)sender).CommandArgument.ToString();

    int pageindex = int.Parse(ViewState["pageindex"].ToString());

    if (strCommand == "pre")
    {
    pageindex = pageindex - 1;
    }
    else
    {
    pageindex = pageindex + 1;
    }

    ViewState["pageindex"] = pageindex;

    BindData();
    }

    至此,我们的分页函数已经写完了。

    转自:http://blog.csdn.net/mane_yao/article/details/5403599

  • 相关阅读:
    经常使用的两个清爽的table样式
    wdcp新开站点或绑定域名打不开或无法访问的问题
    在线客服代码,可以用
    $smarty获取变量get,post等用法
    mysql 替换某个字段中的某个字符
    git 设置不需要输入密码
    linux批量查找文件内容
    使用PHP QR Code生成二维码
    RabbitMQ-2
    RabbitMQ-1
  • 原文地址:https://www.cnblogs.com/eason-chan/p/3657666.html
Copyright © 2011-2022 走看看