top
Loading...
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葉面里調用。分頁做的還不漂亮,高手們可以修改修改,能發給我的話我會負責給您發表出來!
作者:http://www.zhujiangroad.com
來源:http://www.zhujiangroad.com
北斗有巢氏 有巢氏北斗