效果图:
特点:
1.如果参数page可以被解析为数字,则返回相应页码(1-based)的内容。如果页码为负,或页码过大,则返回空白内容。
2.如果参数page不能被解析为数字,则初始化为1。
3.如果参数page为0,则自动纠正为1。
4.每次仅从数据库取出应显示之记录,因此加快了响应速度,节约了网络带宽。
缺陷:
1.页码超范围不会自动纠正。
2.如果页数过多,可能需要对页码进行分页,本程序未考虑之。
3.刷新时PostBack闪屏,不如Ajax。
实现:
0.Database & LINQ to SQL
数据库设计及数据:略。
在App_Code区中新建一个文件(LINQ to SQL Class,扩展名为.dbml),从Server Explorer中拖入所需Table。
(以下代码段实现的结果,近似于用三个控件 LinqDataSource, ListView, DataPager实现。)
1.Code:
// 取得每页条数(读配置)。 int pagesize; pagesize = 5; // 取得页码。 int page; int.TryParse( Request.QueryString["page"], out page ); if (page == 0) page = 1; // 取得总条数(读数据)。 var ctx = new PhotoAlbumDataContext(); int count = ctx.Photos.Count(); // 计算页数。 int pages = count / pagesize; if ((count % pagesize) != 0) pages++; for (int i = 0; i < pages; i++) { Response.Output.Write( "<a href={0}?page={1}>{1}</a> ", Request.Path, i + 1 ); } Response.Write("<br />"); var q = (from a in ctx.Photos select a).Skip( ((page-1)*pagesize) ).Take(pagesize); //ctx.Log = Response.Output; ListView1.DataSource = q; ListView1.DataBind();
2.Page:
<asp:ListView ID="ListView1" runat="server" ItemPlaceholderID="itemContainer"> <LayoutTemplate> <ul id="itemContainer" runat="server" class="photo-list"> </ul> </LayoutTemplate> <ItemTemplate> <li> <img src='<%# Eval("Path") %>' alt='<%# Eval("Name") %>' /> <br /> <%# Eval("Name") %> </li> </ItemTemplate> </asp:ListView>