DataList可以一次显示多条记录且风格自由,可以制作出十分优秀的界面,但其本身不具有分页功能.不过我们可以通过增加几个Label控件,让DataList实现分页功能,示例代码如下:

<tr>
                            <td>
                                <asp:Label ID="lblCurPage" runat="server" Text="Label"></asp:Label>
                            </td>
                            <td>
                                <asp:HyperLink ID="lnkFirst" runat="server">第一页</asp:HyperLink>
                                <asp:HyperLink ID="lnkPerv" runat="server">上一页</asp:HyperLink>
                                <asp:HyperLink ID="lnlNext" runat="server">下一页</asp:HyperLink>
                                <asp:HyperLink ID="lnkLast" runat="server">最后一页</asp:HyperLink>
                            </td>
</tr>

protected void DataListBind()
       {
           AccessDataSource ads = new AccessDataSource();
           ads.SelectCommand = "select * from board order by board_time desc";
           ads.DataFile = "~/App_Data/news.mdb";
           DataView dv = (DataView)ads.Select(DataSourceSelectArguments.Empty);
           PagedDataSource objPage = new PagedDataSource();
           objPage.DataSource = dv;
           objPage.AllowPaging = true;
           objPage.PageSize = 2;
           Int32 CurPage,TolPage;
           TolPage = objPage.PageCount;
           if (Request.QueryString["Page"] != null)
           {
               CurPage = Convert.ToInt32(Request.QueryString["Page"]);
           }
           else
           {
               CurPage = 1 ;
           }
           objPage.CurrentPageIndex = CurPage - 1;
           lblCurPage.Text = "当前第" + CurPage.ToString() + "页,共" + TolPage.ToString()+"页";

           lnkFirst.NavigateUrl=Request.CurrentExecutionFilePath+"?Page=1&main_];
           }
           else
           {
               lnlNext.Visible = false;
               lnkLast.Visible = false;
           }
           DataList1.DataSource = objPage;
           DataList1.DataBind();
       }

相关文章: