ASP万用分页程序

王朝asp·作者佚名  2006-11-24
窄屏简体版  字體: |||超大  

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

下面这段是基本的分页代码:

<% 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 %>

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

<% 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来引入他调用的时候只要 Call("/你调用的文件名?")就ok了,比如我的 news页面里要调用那么就是<%Call("/news.asp?")%>

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

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有  導航