自定义ASP.Net DataPager生成的HTML

前端之家收集整理的这篇文章主要介绍了自定义ASP.Net DataPager生成的HTML前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我在我的web项目中使用ListView和DataPager进行分页.它工作正常,但生成分页 HTML只是一个包含一些超链接的span.

我想自定义HTML并在无序列表中显示链接(ul).

有人知道如何做到这一点?我能想到的一种方法是CSSFriendly适配器,但如果有更简单的方法,我不想这样做.

编辑:有人可以帮助我完成在模板中创建控件所需的确切步骤吗?抱歉愚蠢,但我无法想象这一部分,尽管广泛的谷歌搜索.

解决方法

您可以使用PagerTemplate指定要用于分页控件的标记.我不确定你在显示分页信息方面正在尝试做什么,如ul / li,但这应该足以让你在正确的轨道上开始.对不起,代码长跑到一边……

例如:

<asp:DataPager ID="DataPager1" runat="server" PagedControlID="gridInvoiceHistory"
            PageSize="20">
            <Fields>
                <asp:TemplatePagerField>
                    <PagerTemplate>
                        Page
                        <asp:Label runat="server" ID="labelCurrentPage" Text="<%# Container.TotalRowCount > 0 ? (Container.StartRowIndex / Container.PageSize) + 1 : 0 %>" />
                        of
                        <asp:Label runat="server" ID="labelTotalPages" Text="<%#  Math.Ceiling ((double)Container.TotalRowCount / Container.PageSize) %>" />
                    </PagerTemplate>
                </asp:TemplatePagerField>

编辑:这是一个更详细的解决方案:

<asp:TemplatePagerField>
     <PagerTemplate>
          <asp:BulletedList ID="listPages" runat="server" 
               DisplayMode="LinkButton" onclick="listPages_Click">
          </asp:BulletedList> 
     </PagerTemplate>
</asp:TemplatePagerField>

以下是代码隐藏中的内容

protected void listPages_Click(object sender,BulletedListEventArgs e)
        {
            var pageNo = int.Parse((sender as BulletedList).Items[e.Index].Text);
            var startIndex = (pageNo - 1) * DataPager1.PageSize;
            DataPager1.SetPageProperties(startIndex,DataPager1.PageSize,true);
        }

您还需要做的是针对获取页面计数的方法对项目符号列表执行数据绑定,并返回页面链接所需文本的IEnumerable列表.标准警告:这是示例代码,如果没有彻底的审查,可能不应该在生产环境中使用!

猜你在找的asp.Net相关文章