用代码分页(.NET 3.5, C#, LINQ to SQL Classes, ListView)

效果图:

image

特点:

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。

image

(以下代码段实现的结果,近似于用三个控件 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>&nbsp;&nbsp;",
        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>
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值