`

.net实现google,baidu样式的分页

阅读更多

做一个项目,用到了DATALIST,由于分页的需求,手动写了分页的函数。个人觉得GOOGLE的分页很不错,上网查了下资料,修改了下。
           

这里没有涉及到数据的分页读取,只是返回一个带HTML代码的分页样式(字符串),可以用label在页面显示,也可以用this.Controls.Add(new LiteralControl(string));方法加入到页面控件中。

Demo1:

 

using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Text;

/// <summary>
/// Pagenumber 的摘要说明
/// </summary>
public static class Pagenumber
{
    ///   <summary> 
         ///  创建并显示分页器
         ///   </summary> 
    public static string BuildPager(int totalRecords, int currentPage, int pageSize, int pid)
    {
        int alter = 4;
        int startPage = 1;
        int endPage = currentPage + alter;
        int totalPages = CalculateTotalPages(totalRecords, pageSize);

        if (currentPage > alter)
        {
            startPage = currentPage - alter;
        }

        if (endPage > totalPages)
        {
            endPage = totalPages;
        }

        string strTemp = @" <a href='Default.aspx?p={0}&pno={1}'>{2}</a>&nbsp; ";
        StringBuilder sb = new StringBuilder("");
        if (currentPage != startPage)
        {
            sb.Append(string.Format(strTemp, currentPage - 1, currentPage - 1, " 上一页 "));
        }

        for (int i = startPage; i <= endPage; i++)
        {
            if (currentPage == i)
            {
                sb.Append(" <font color=red> " + i + " </font>&nbsp;&nbsp; ");
            }
            else
            {
                sb.Append(string.Format(strTemp, i, i, "[" + i + "]"));
            }
        }

        if (currentPage != endPage)
        {
            sb.Append(string.Format(strTemp, currentPage + 1, currentPage + 1, " 下一页 "));
        }

        return sb.ToString();
    }
 
          /**/ ///   <summary> 
         ///  计算总页数
         ///   </summary> 
         ///   <param name="totalRecords"> 总记录数 </param> 
         ///   <param name="pageSize"> 每页记录数 </param> 
    public static int CalculateTotalPages(int totalRecords, int pageSize)
    {
        int totalPagesAvailable;

        totalPagesAvailable = totalRecords / pageSize;

        // 由于C#的整形除法 会把所有余数舍入为0,所以需要判断是否需要加1 
        if ((totalRecords % pageSize) > 0)
            totalPagesAvailable++;

        return totalPagesAvailable;
    }
}

 

Demo2:

 

  /**//// <summary>
          /// 类似GOOGLE的分页函数,王传炜,资料参考http://www.phpx.com/happy/viewthread.php?tid=99280&extra=&page=2,谢谢YourEyes
           /// </summary>
          /// <param name="total">总记录数</param>
          /// <param name="per">每页记录数</param>
          /// <param name="page">当前页数</param>
          /// <param name="query_string">Url参数</param>
           private string pagination(int total,int per,int page,string query_string)
           {
               int allpage=0;
               int next=0;
               int pre=0;
               int startcount=0;
               int endcount=0;
               string pagestr=""; 
               if(page<1){page=1;}
               //计算总页数
              if (per != 0)
               {
                   allpage = (total / per);
                   allpage = ((total % per) != 0 ? allpage + 1 : allpage);
                   allpage = (allpage == 0 ? 1 : allpage);
               }
               next=page+1;
               pre=page-1;
             startcount=(page+5)>allpage?allpage-9:page-4;//中间页起始序号
               //中间页终止序号
               endcount = page<5 ? 10 : page+5;
               if(startcount<1) {startcount=1;} //为了避免输出的时候产生负数,设置如果小于1就从序号1开始
               if(allpage<endcount){endcount=allpage;}//页码+5的可能性就会产生最终输出序号大于总页码,那么就要将其控制在页码数之内
               pagestr="共"+ allpage +"页&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;";
             
               pagestr+=page>1 ?  "<a href=\""+ query_string + "?page=1\">首页</a>&nbsp;&nbsp;<a href=\""+ query_string +"?page="+ pre +"\">上一页</a>": "首页 上一页";
                //中间页处理,这个增加时间复杂度,减小空间复杂度
                for(int i=startcount;i<=endcount;i++)
                { 
                    pagestr+=page==i?"&nbsp;&nbsp;<font color=\"#ff0000\">"+i+"</font>":"&nbsp;&nbsp;<a href=\""+ query_string +"?page="+ i +"\">"+ i +"</a>";
                }
                pagestr+=page!=allpage ? "&nbsp;&nbsp;<a href=\""+ query_string+"?page="+ next +"\">下一页</a>&nbsp;&nbsp;<a href=\""+ query_string +"?page="+ allpage+"\">末页</a>" : " 下一页 末页";
  
               return pagestr;           
           }

   

如果再加上 分页存储过程  就可以满足大部分需求了。

一个分页存储过程

在这里整理了两个可以用的分页存储过程,以备后用。

第一:

 

ALTER  procedure Consignment
@tablename varchar(80) ,
@strOrder varchar(50) ,
@PageIndex int = 1,
@PageSize int = 15,
@strGetFields varchar(200) = '*',
@OutPut int output
as 
Begin
Declare @strSql varchar(500)

DECLARE   @SQL   NVARCHAR(1000)
DECLARE   @R BIGINT
SET   @SQL=  N'select @R=count(*) from  '+@TableName
EXEC  SP_EXECUTESQL   @SQL,  N' @R BIGINT OUTPUT',  @R OUTPUT
SET   @OutPut=  @R

if(@PageIndex =1)
Begin
   set @strSql='select top '+str(@PageSize)+' '+@strGetFields+' from '+@tablename+' order by '+@strOrder
End
Else
   set @strSql='select top '+str(@PageSize)+' '+@strGetFields+' from '+@tablename+' where ('+@strOrder
             +' >= ( select Max('+@strOrder+') from ( select top '+str(@PageSize*@PageIndex)+' * from '+@tablename+' order by '
             +@strOrder+' ) as tempTable)) order by '+ @strOrder
   select @strSql  
exec(@strSql)

End

 

第二:

alter procedure AllProce
@tablename varchar(200) ,   --表名
@strGetFields varchar(200) = '*',  --查询列名
@PageIndex int = 1 ,         --页码
@pageSize int = 15,         --页面大小
@strWhere  varchar(100) = '',     --查询条件
@strOrder varchar(100) = '', --排序列名
@intOrder bit = 0,        --排序类型  1为升序
@CountAll bigint output              --返回纪录总数用于计算页面数    
as
begin
declare @strSql varchar(500)  --主语句
declare @strTemp varchar(100) --临时变量
declare @strOrders varchar(50) --排序语句
declare @table varchar(70)

declare   @SQL   nvarchar(1000)
declare   @R bigint
set   @SQL=  N'select @R=count(*) from  '+convert(nvarchar(200),@TableName)
exec  SP_EXECUTESQL   @SQL,  N' @R BIGINT OUTPUT',  @R OUTPUT
set   @CountAll=  @R
if @intOrder = 0
begin
    --为0是升序
    set @strTemp = '>(select max'
    set @strOrders =  ' order by  '+@strOrder+' asc '
end
else
begin
    --否则为降序
    set @strTemp = '<(select min'
    set @strOrders = ' order by  '+@strOrder+' desc '
end
if @PageIndex =1        --第一页直接读出纪录
begin
    if @strWhere = ''
    begin
         set @strSql = 'select top '+str(@pageSize)+' '+@strGetFields+' from '+@tablename+' '+@strOrders
     end
    else  
    begin
         set @strSql = 'select top '+str(@pageSize)+' '+@strGetFields+ ' from '+@tablename+' where '+@strWhere+' '+@strOrders
    
    end
end
else
begin
    set @strSql = 'select top'+str(@pageSize)+' '+@strGetFields+' from '+@tablename+' where '+@strOrder+' '+@strTemp+' ('+@strOrder+')'
                  +' from (select top '+str((@pageIndex-1)*@pageSize)+' '+@strGetFields+' from '+@tablename+ ' '+@strOrders+ ') as tempTable ) '+@strOrders
         
    if @strWhere != ' '
    begin
       set @strSql = 'select top '+str(@pageSize)+ ' '+@strGetFields+' from '+@tablename+ ' where '+@strOrder+ ' '+@strTemp+' ('+@strOrder+') '
                   +' from(select top '+str((@pageIndex-1)*@pageSize)+' '+@strGetFields+' from '+@tablename+' where '+@strWhere+' ' +@strOrders+') as tempTable) where '+@strWhere+' '+@strOrders
   
    end
end 
exec(@strSql)    
end
GO

 

 

 

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/lcfgaoyong/archive/2006/04/20/670806.aspx

分享到:
评论

相关推荐

    asp.net分页 类似百度 的分页

    标题提到的“asp.net分页 类似百度的分页”指的是创建一个类似百度搜索结果那样具有高效、用户友好的分页功能。在描述中提到没有使用存储过程,这意味着我们将探讨如何通过纯代码方式在ASP.NET中实现分页。 首先,...

    ViewState分页

    ViewState分页是ASP.NET开发中常见的一种实现网页数据分页的方法。它利用了ASP.NET页面状态管理机制中的ViewState属性,将分页相关的参数(如当前页数、总页数等)编码并存储在HTML页面中,以便在页面回发时保持这些...

    asp.net模拟百度分页+sqlhelper类

    在本示例中,"asp.net模拟百度分页+sqlhelper类"是指利用ASP.NET技术来实现类似于百度搜索引擎那样的分页功能,同时结合SQLHelper类进行数据库操作。 百度分页是百度搜索引擎展示搜索结果时采用的一种用户体验优化...

    ASP.NET2.0中datalist仿百度分页

    通过以上步骤,我们可以在ASP.NET 2.0中实现一个类似于百度的分页功能。DataList控件的灵活性使得我们可以自由地定制分页样式和行为,以满足不同项目的需求。在实际开发中,还可以考虑添加缓存机制、服务器端和...

    基于ASP.NET实现百度文库

    期末作业做的ASP.NET实现百度文库功能; 后台把上传的DOC,PPT,XLS,PDF文件转换为SWF文件,并提取出文档第一张图保存为JPG格式,tools文件夹中包含了转换需要的转换工具,调用了Office COM组件,成功转换需要安装...

    asp.net实现百度关键字搜索

    在ASP.NET中实现百度关键字搜索涉及到了Web开发技术、搜索引擎接口调用以及数据解析等多个方面的知识。下面将详细讲解这些知识点: 1. ASP.NET基础:ASP.NET是微软公司推出的一种用于构建Web应用程序的框架,它基于...

    .net实现选课系统

    《.NET实现选课系统详解》 在信息技术飞速发展的今天,.NET框架以其强大的功能和易用性,成为许多开发者构建复杂应用的首选平台。本文将深入探讨如何利用.NET技术来实现一个选课系统,从数据库连接到前端展示,全...

    ASP.Net实现SQL动态绑定Echarts图表Demo完整源码

    【ASP.Net实现SQL动态绑定Echarts图表Demo完整源码】是一个示例项目,它演示了如何在ASP.Net环境中结合Echarts图表库、C#、SQL和JSON技术来动态展示数据库中的数据。该项目的核心目标是利用后端服务器处理程序获取...

    FlexPaper+SWFTools+ASP.NET实现仿百度文库源码

    FlexPaper+SWFTools+ASP.NET实现仿百度文库源码是一种在线文档预览和分享的解决方案,它结合了多种技术来提供类似百度文库的功能。这个系统的主要目的是让用户能够方便地上传、浏览和分享各种格式的文档,如PDF、DOC...

    jsp仿百度、谷歌分页解决分页太多,始终显示一部分的页码

    在传统的分页实现中,所有页码都会显示出来,但这可能导致页面显得过于复杂,尤其是在有几百甚至上千页的情况下。 百度和谷歌的分页设计巧妙地解决了这个问题,它们只显示一部分页码,并在两端添加省略号,表示存在...

    asp.net实现百度文库功能(asp.net调用flashpaper)

    在这个特定的项目中,"asp.net实现百度文库功能(asp.net调用flashpaper)"是创建一个类似于百度文库的在线文档查看平台,用户可以上传各种类型的文档,并通过FlashPaper技术将其转换为SWF(ShockWave Flash)文件,...

    asp分页,asp分页仿百度,asp分页大全

    四、ASP分页实现方法 1. 传统SQL分页:直接在SQL查询中使用LIMIT和OFFSET子句(如MySQL)或者TOP和ROW_NUMBER()函数(如SQL Server)来获取指定页的数据。 2. 存储过程分页:在数据库层面编写存储过程,将分页逻辑...

    asp.net调用flashpaper实现类似百度文库的功能解决方案

    ### ASP.NET调用FlashPaper实现类似百度文库的功能解决方案 #### 概述 在Web开发领域,特别是文档处理方面,ASP.NET与FlashPaper的结合能够有效地实现文档预览功能,类似于百度文库这样的应用场景。本篇文章将深入...

    在asp.net WebForm中的easyUI分页+条件检索

    以前没用过这东西,百度感觉资源也少,所以做完分享个。只是个练习,勿喷谢谢。题目写的很清楚 Index.aspx是主文件。Select.cs是检索用的字段。tbl_User.cs是表的实体类。ToJson.ashx你懂得。就这几个文件了,再有...

    ASP.net版百度贴吧,本人自行开发,源码奉上

    在本项目"ASP.NET版百度贴吧"中,开发者使用了ASP.NET技术来模拟和实现类似百度贴吧的功能。 【VS2003开发环境】 Visual Studio 2003(简称VS2003)是微软早期的一款集成开发环境,支持.NET Framework 1.1版本的...

    ASP.NET 仿百度智能搜索 快速搜索

    在本项目中,"ASP.NET 仿百度智能搜索 快速搜索" 的目标是实现一个类似百度搜索引擎的功能,即在用户输入关键词时,利用Ajax技术实现实时的搜索建议和快速反馈结果。 首先,我们要理解什么是Ajax(Asynchronous ...

    ASP.NET调用百度地图API实例

    这个实例中,开发者利用ASP.NET的网页编程能力结合百度地图的JavaScript API,实现了动态地在网页上展示地图、定位、标记等功能。 首先,让我们了解一下ASP.NET。ASP.NET是由微软开发的一个用于构建Web应用程序的...

    datalist2种分页样式源码源数据库

    在这个项目中,我们关注的是“datalist2种分页样式源码源数据库”,它提供了两种分页样式:数字分页,模仿了百度和Google的分页效果,并且附带了源代码和源数据库。这个解决方案旨在实现一个无需额外控件的分页功能...

    vb.net实现多标签网页浏览器

    【VB.NET实现多标签网页浏览器】是一个基于VB.NET 2008开发的应用程序,它提供了类似现代浏览器的用户体验,支持多个标签同时打开不同的网页,同时也集成了百度搜索引擎,使得用户可以直接在应用程序内部进行网络...

    使用Asp.net实现的联合登陆

    在Asp.net开发环境中,联合登录(也称为OpenID Connect或OAuth2)是一种常见的功能,允许用户通过第三方账号(如QQ、新浪微博、百度等)进行登录,极大地提升了用户体验。本项目实现了这一功能,并且提供了相应的...

Global site tag (gtag.js) - Google Analytics