首 页 网络编程
网页制作 图形图象 操作系统 冲浪宝典
软件教学 认证考试

网络安全 网络办公 行业资讯 评测对比
您当前位置:站长天空 -> 网络编程-> Delphi教程
支持多风格变换的asp分页类_asp技巧
作者:网友供稿 点击:0
推荐
西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!可在线rar解压,自动数据恢复设置虚拟目录等.免费赠送访问统计,企业邮局.Cn域名注册10元/年,自助建站480元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金
站内搜索
文章页数:[1] 

这个分页使用的是0游标,也就是Rs.Open Sql,Conn,0,1。但是感觉也快不了多少,10
万条数据的分页时间300多豪秒之间
<%
Class Page
Private CurrPage
Private PageN
Private UrlStr
Private TempStr
Private ErrInfo
Private IsErr
Private TotalRecord
Private TotalPage
Public  PageRs

Private TempA(11)
Private TempB(8)
------------------------------------------------------------
Private Sub Class_Initialize()
      CurrPage=1//默认显示当前页为第一页
      PageN=10//默认每页显示10条数据
      UrlStr="#"
      TempStr=""
      ErrInfo="ErrInfo:"
      IsErr=False
End Sub
Private Sub Class_Terminate()
      If IsObject(PageRs) Then
            PageRs.Close
            Set PageRs=Nothing
      End If
      Erase TempA
      Erase TempB
End Sub
----------------------------------------------------------
//获取当前页码
Public Property Let CurrentPage(Val)
      CurrPage=Val
End Property
Public Property Get CurrentPage()
      CurrentPage=CurrPage
End Property
//获取每页显示条数
Public Property Let PageNum(Val)
      PageN=Val
End Property
Public Property Get PageNum()
      PageNum=PageN
End Property
//获取URL
Public Property Let Url(Val)
      UrlStr=Val
End Property
Public Property Get Url()
      Url=UrlStr
End Property
//获取模板
Public Property Let Temp(Val)
      TempStr=Val
End Property
Public Property Get Temp()
      Temp=TempStr
End Property
------------------------------------------------------------

Public Sub Exec(Sql,ConnObj)
      On Error Resume Next
      Set PageRs=Server.CreateObject("ADODB.RecordSet")
      PageRs.CursorLocation = 3 使用客户端游标,可以使效率提高
      PageRs.PageSize = PageN 定义分页记录集每页显示记录数
      PageRs.Open Sql,ConnObj,0,1
      If Err.Number<>0 Then
        Err.Clear
     PageRs.Close
     Set PageRs=Nothing
        ErrInfo=ErrInfo&"建立或打开记录集错误..."
     IsErr=True
     Response.Write ErrInfo
     Response.End
      End If
      TotalRecord=PageRs.RecordCount//如果为0呢?
      If TotalRecord>=1 Then
      ----------------------------------------------------------------------------开始
      //计算总页数,Ps,为什么不用PageRs.PageCount呢?
      If TotalRecord Mod PageN=0 Then
        TotalPage=PageRs.RecordCount\PageN
      Else
        TotalPage=PageRs.RecordCount\PageN
     TotalPage=Abs(Int(TotalPage))
      End If
   TotalPage=PageRs.PageCount
      //处理当前接收页码,默认的为1,所以不是数字类型的都会为1
      If IsNumeric(CurrPage) Then
         CurrPage=CLNg(CurrPage)
         If CurrPage<1 Then CurrPage=1
      If CurrPage>TotalPage Then CurrPage=TotalPage
      Else
            //Dim M:M="":IsNumeric(M)=True
         CurrPage=1
      End If
      ---------------------------------------------------------------------------结束
      Else
         TotalPage=0
         CurrPage=1
      End If
      //
      PageRs.AbsolutePage = CurrPage absolutepage:设置指针指向某页开头
      PageRs.PageSize=PageN
End Sub
Private Sub Init()
      Private TempA(10)
      TempA(1)="{N1}" //首页
      TempA(2)="{N2}"//上一页
      TempA(3)="{N3}"//下一页
      TempA(4)="{N4}"//尾页
      TempA(5)="{N5}"//当前页码
      TempA(6)="{N6}"//页码总数
      TempA(7)="{N7}"//每页条数
      TempA(8)="{N8}"//文章总数
      TempA(9)="{L}"//循环标签开始
      TempA(10)="{N}"//循环内单标签:页码
      TempA(11)="{L/}"//循环标签结束
      Private TempB(8)
      TempB(1)="首页"
      TempB(2)="上一页"
      TempB(3)="下一页"
      TempB(4)="尾页"
      TempB(5)=CurrPage//当前页码
      TempB(6)=TotalPage//页码总数
      TempB(7)=PageN//每页条数
      TempB(8)=TotalRecord//文章总数
End Sub
Public Sub Show(Style)
      If IsErr=True Then
        Response.Write ErrInfo
     Exit Sub
      End If

      Call Init()
      Select Case Style
      Case 1
         Response.Write StyleA()
      Case 2
         Response.Write StyleB()
      Case 3
         Response.Write StyleC()
      Case 4
         Response.Write StyleD()
      Case Else
         ErrInfo=ErrInfo&"不存在当前样式..."
      Response.Write ErrInfo
      End Select
End Sub
Public Function ShowStyle(Style)
      If IsErr=True Then
        ShowStyle=ErrInfo
     Exit Function
      End If

      Call Init()
      Select Case Style
      Case 1
         ShowStyle= StyleA()
      Case 2
         ShowStyle= StyleB()
      Case Else
         ErrInfo=ErrInfo&"不存在当前样式..."
  ShowStyle=ErrInfo
      End Select
End Function

Private Function StyleA()
首页 上一页 下一页 尾页  本页为第1/20页,共20页,每页10条,文章总数200条
//分页样例:[首页] [上页] [下页] [尾页] [页次:4/5页] [共86篇 20篇/页] 转到:_ 页
//标签:{N1} {N2} {N3} {N4} || 共:{N8}条记录 {N6}页 当前为第{N5}页 每页{N7}条
If IsEmpty(TempStr) Then
      ErrInfo=ErrInfo&"模板为空..."
      StyleB=ErrInfo
      Exit Function
End If
Dim M
If TotalPage>1 Then
      If CurrPage>1 Then
        M="<a href="&UrlStr&"Page=1>"&"首页"&"</a>"
     TempStr=Replace(TempStr,"{N1}",M)
     M="<a href="&UrlStr&"Page="&CurrPage-1&">"&"上一页"&"</a>"
     TempStr=Replace(TempStr,"{N2}",M)
     If CurrPage<TotalPage Then
       M="<a href="&UrlStr&"Page="&CurrPage+1&">"&"下一页"&"</a>"
    TempStr=Replace(TempStr,"{N3}",M)
    M="<a href="&UrlStr&"Page="&TotalPage&">"&"尾页"&"</a>"
          TempStr=Replace(TempStr,"{N4}",M)
        Else
       TempStr=Replace(TempStr,"{N3}","下一页")
    TempStr=Replace(TempStr,"{N4}","尾页")
     End If
      Else
        TempStr=Replace(TempStr,"{N1}","首页")
     TempStr=Replace(TempStr,"{N2}","上一页")
        M="<a href="&UrlStr&"Page="&CurrPage+1&">"&"下一页"&"</a>"
     TempStr=Replace(TempStr,"{N3}",M)
     M="<a href="&UrlStr&"Page="&TotalPage&">"&"尾页"&"</a>"
        TempStr=Replace(TempStr,"{N4}",M)
      End If
Else
      TempStr=Replace(TempStr,"{N1}","首页")
      TempStr=Replace(TempStr,"{N2}","上一页")
      TempStr=Replace(TempStr,"{N3}","下一页")
      TempStr=Replace(TempStr,"{N4}","尾页")
End If
T=TempStr
T=Replace(T,"{N8}",TotalRecord)
T=Replace(T,"{N6}",TotalPage)
T=Replace(T,"{N5}",CurrPage)
T=Replace(T,"{N7}",PageN)
TempStr=T
StyleA=TempStr
End Function

Private Function StyleB()
首页 |< 1 2 3 4 5 6 7 >| 尾页
//标签:{N1} {N2} {L}{N}{L/}{N3}{N4}
If IsEmpty(TempStr) Then
      ErrInfo=ErrInfo&"模板为空..."
      StyleB=ErrInfo
      Exit Function
End If
Dim ForceNum,BackNum//当前页的前面和后面显示个数
ForceNum=5
BackNum=4
Dim M
//首页
M="<a href="&UrlStr&"Page=1>"&TempB(1)&"</a>"
TempStr=Replace(TempStr,"{N1}",M)
//尾页
M="<a href="&UrlStr&"Page="&TempB(6)&">"&TempB(4)&"</a>"
TempStr=Replace(TempStr,"{N4}",M)
//前一页
M="|<"
If CurrPage-1>=1 Then
      M="<a href="&UrlStr&"Page="&CurrPage-1&">"&"|<"&"</a>"
End If
TempStr=Replace(TempStr,"{N2}",M)
//后一页
M=">|"
If CurrPage+1<=TotalPage Then
      M="<a href="&UrlStr&"Page="&CurrPage+1&">"&">|"&"</a>"
End If
TempStr=Replace(TempStr,"{N3}",M)
//取出循环标签
Dim N1,N2,N3,N4,N5,N6
If InStr(TempStr,"{L}")>0 Then
      N1=InStr(TempStr,"{L}")
End If
If InStr(TempStr,"{L/}")>0 Then
      N2=InStr(TempStr,"{L/}")
End If
If N2<=N1 Then
      ErrInfo=ErrInfo&"循环标签出错..."
      StyleB=ErrInfo
      Exit Function
End If
N3=Mid(TempStr,N1,N2-N1+4)//储存包括{L}{L/}循环标签的模板
N4=Replace(N3,"{L}","")//储存不包括{L}{L/}循环标签的模板
N4=Replace(N4,"{L/}","")
//页码列表
Dim FirstPageNum,LastPageNum
If CurrPage-ForceNum<=1 Then
   FirstPageNum=1
   PageList=""
Else
   FirstPageNum=CurrPage-ForceNum
   PageList="... ..."
End If
If CurrPage+BackNum>=TotalPage Then
   LastPageNum=TotalPage
   PageList_2=""
Else
   LastPageNum=CurrPage+BackNum
   PageList_2="... ..."
End If
Dim I
For I=FirstPageNum To LastPageNum
      If I=CurrPage Then
        N5=Replace(N4,"{N}","<b>"&I&"</b>")
     N6=N6&N5
      Else
        M="<a href="&UrlStr&"Page="&I&">"&I&"</a>"
     N5=Replace(N4,"{N}",M)
     N6=N6&N5
      End If
Next
TempStr=Replace(TempStr,N3,N6)
StyleB=TempStr
End Function

Private Function StyleC()
首页 |< |<< 1 2 3 4 5 6 7 >>| >| 尾页
//此风格在StyleB的基础上修改,增加两个标签:{N9}上10页 {N10}下10页
//标签:{N1}{N2}{N9}{L}{N}{L/}{N10}{N3}{N4}
Dim T
T=StyleB()
//前十页
M="|<<"
If CurrPage-10>=1 Then
      M="<a href="&UrlStr&"Page="&CurrPage-10&">"&"|<<"&"</a>"
End If
T=Replace(T,"{N9}",M)
M=">>|"
If CurrPage+10<=TotalPage Then
      M="<a href="&UrlStr&"Page="&CurrPage+10&">"&">>|"&"</a>"
End If
T=Replace(T,"{N10}",M)
StyleC=T
End Function

Private Function StyleD()
//此风格在StyleC的基础上修改
//共{N8}条记录 {N6}页 当前为第{N5}页 每页{N7}条
//首页 |< |<< 1 2 3 4 5 6 7 >>| >| 尾页
//标签:{N1}{N2}{N9}{L}{N}{L/}{N10}{N3}{N4}
Dim T
T=StyleC()
T=Replace(T,"{N8}",TotalRecord)
T=Replace(T,"{N6}",TotalPage)
T=Replace(T,"{N5}",CurrPage)
T=Replace(T,"{N7}",PageN)
StyleD=T
End Function

End Class
%>


文章整理:站长天空 网址:http://www.z6688.com/
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

文章页数:[1] 


放大字体显示 缩小字体显示 打印文章 推荐给朋友
热门文章
·ListBox控件基本功能-.NET教程,组件控件开发
·用window.location.href实现刷新另个框架页面-.NET教程,Asp.Net开发
·JSP+STRUTS+EJB+DAO+HIBERNATE实例-JSP教程,Jsp/Servlet
·.NET中的设计模式四:命令模式-.NET教程,Asp.Net开发
·数字转英文(货币)大写-.NET教程,数据库应用
·用户控件用户登录判断-ASP教程,客户端相关
·计数器的另一用法:自动切换首页图片-ASP教程,ASP应用
·漫谈Java数据库存取技术-JSP教程,Java技巧及代码
·正则表达式-.NET教程,Asp.Net开发
·即时通讯靠免费短信能赚10亿?
最新文章
·让flash动画适应任何分辨率的网页_flash教程
·新手必看之网站的定位篇_站长心得
·1000ip的效益也能大于一万ip_网赚技巧
·google adsense课堂:西联快汇知识_网赚技巧
·googleadsense的无效点击_google推广
·google adsense高价关键字[排行榜]_google推广
·google搜索引擎的十大应用_google推广
·windows vista下如何关闭远程控制_windows vista
·修改配置 让windows vista系统实现自动登录_windows vista
·整齐划一 将整个网页保存在一个文件中_站长心得
相关主题
西部数码虚拟主机

友情链接
CNNIC 西部数码
万网 自助建站
虚拟主机 asp空间
域名注册 域名
域名申请 主页空间
论坛空间 网站空间
国际域名 虚拟空间
空间租用 DDOS防火墙
成都主机托管 四川主机托管
主机租用 服务器租用
网站目录 自助建站
虚拟主机 网址大全
软件下载
自助链接
虚拟主机资讯 特价虚拟主机
版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!
关于我们:站长天空:专业提供最新的站长资讯、在线教程、虚拟主机权威评测、虚拟主机性能对比、网站制作教程,开发教程,站长工具。包括网页制作教程、冲浪宝典、编程参考、操作系统、软件教学、行业动态等。
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
发表评论 打印  刷新     关闭