程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> ASP編程 >> 關於ASP編程 >> ASP萬用分頁程序

ASP萬用分頁程序

編輯:關於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?")%>

剛才我們所到這是有限制的意思就是說第一段代碼裡除了sql查詢內容和輸出內容可以更改,其他的聲明記錄集的對象,page, pages, allpages這些變量都不能更改,否則將無法運行~其實這個程序是無關緊要的,最主要的就是,這個分頁函數可以在任何一個asp葉面裡調用。
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved