栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

使用中继器和SQL进行自定义分页

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

使用中继器和SQL进行自定义分页

您可以创建一个自定义方法来呈现自己的分页控件。这是一个例子:

    /// <summary>    /// Produces html for a pagination control.    /// </summary>    /// <param name="page">Page number for the current page (1-based index).</param>    /// <param name="pageSize">Number or items per page.</param>    /// <param name="totalItems">Total number of items across all pages.</param>    /// <returns>Html of a pagination control.</returns>    public string RenderPaginationControl(int page, int pageSize, int totalItems)    {        int totalPages = (int)Math.Ceiling((double)totalItems/pageSize);        // Create pager.        StringBuilder pagerSb = new StringBuilder();        for (int i = 1; i <= totalPages; ++i)        { // If it is NOT a link to current page. if (i != page) { pagerSb.Append(string.Format("<a href='/data.aspx?page={0}'>{0}</a>", i)); } // If it is the link to current page. else { pagerSb.Append(string.Format("<span>{0}</span>", i)); }        }        return pagerSb.ToString();    }

如您所见,除了sql之外,您还需要调用

SELECt COUNT(*) FROM Items

并通过该值 TOTALITEMSRenderPaginationControl

就与Repeater的绑定而言,这很简单:

this.MyRepeater.DataSource = DAL.GetItems(page, pageSize);this.MyRepeater.DataBind();int totalItems = DAL.GetTotalNumberOfItems();this.PaginationLabel.Text = RenderPaginationControl(page, pageSize, totalItems);


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/420120.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号