七彩课堂·网页设计知识教程
ASP万用分页程序
 这只是个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?")%>

 
信息推荐