notice

致江湖上的朋友:
  欢迎您访问╃苍狼山庄╃请使用侧边栏的搜索功能查找日志,希望能在这里找到您所需要的东西,使您在平淡之中充满喜悦。

Clang 出品,必属精品! 我的地盘我做主! 活着,真累!
本站域名:Http://ClangCN.Com/(点击加入收藏夹)
欢迎您再来,谢谢!!!
Clang 于2006年01月09日

ASP万用分页程序

2006年1月11日 | 分类: 程序代码 | 标签:

这只是个asp小技巧类的东西,它虽然适合在每个不同文件名里调用这个函数,但是也是有前提的,下面让我们来仔细看看其中的原委。
下面这段是基本的分页代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
<% sql = "select  ……………………" '省略了sql语句 
 Set rs=Server.Createobject("ADODB.RECORDSET") 
 rs.Open sql, conn, 1, 1 
 if not rs.eof then 
  pages = 30 '定义每页显示的记录数 
  rs.pageSize = pages'定义每页显示的记录数 
  allPages = rs.pageCount'计算一共能分多少页 
  page = Request.QueryString("page")'通过浏览器传递的页数 
  'if语句属于基本的排错处理 
  if isEmpty(page) or Cint(page) < 1 then 
   page = 1 
  elseif Cint(page) > allPages then 
   page = allPages 
  end if 
  rs.AbsolutePage = page 
  Do while not rs.eof and pages > 0 %> 
   这里输出你要的内容……………… 
   <% pages = pages - 1 
   rs.MoveNext 
  Loop 
 else 
  Response.Write("数据库暂无内容!") 
End if 
 rs.Close 
 Set rs = Nothing %>

  系统已经为数据分页了,下面就看看这次探讨的关键问题分页函数的定义

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<% SUB pageUrl(pUrl) 
 Dim eUrl 
txts = Request.ServerVariables("URL") 
 txts = left(txts,instrrev(txts,"/",len(txts))-1) 
 eUrl = "http://" & Request.ServerVariables("server_name") & txts 
 For i =1 to allpages 
  txt = "" 
  txt = "<strong>" 
  txt = txt & "<a href=" & eUrl & pUrl & "page="&i & ">" 
  if i = Cint(Page) then txt = txt & "<font color='#bb0000'>" 
   txt = txt & (i) 
   if i = Cint(Page) then txt = txt & "</font>" 
    txt = txt & "</a> || </strong>" 
    Response.Write(txt) 
 Next 
END sub %>

把上面这个分页函数代码COPY存成一个ASP文件,在需要使用的页面里用include来引入他调用的时候只要

1
Call("/你调用的文件名?")

就ok了,比如我的 news页面里要调用那么就是

1
<%Call("/news.asp?")%>

刚才我们所到这是有限制的意思就是说第一段代码里除了sql查询内容和输出内容可以更改,其他的声明记录集的对象,page, pages, allpages这些变量都不能更改,否则将无法运行~其实这个程序是无关紧要的,最主要的就是,这个分页函数可以在任何一个asp叶面里调用。分页做的还不漂亮,高手们可以修改修改,能发给我的话我会负责给您发表出来!

-------------------------End-------------------------

本文的评论功能被关闭了.