ASP萬用分頁程序
下面這段是基本的分頁代碼:
<% sql = "select……………………省略了sql語句 Set rs=Server.Createobject("ADODB.RECORDSET") rs.Open sql, conn, 1, 1 if not rs.eof then pages = 30 '定義每頁顯示的記錄數(shù) rs.pageSize = pages '定義每頁顯示的記錄數(shù) allPages = rs.pageCount'計(jì)算一共能分多少頁 page = Request.QueryString("page")'通過瀏覽器傳遞的頁數(shù) 'if語句屬于基本的排錯(cuò)處理 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 %> 這里輸出你要的內(nèi)容……………… ?。? pages = pages - 1 rs.MoveNext Loop else Response.Write("數(shù)據(jù)庫(kù)暫無內(nèi)容!") End if rs.Close Set rs = Nothing %>
系統(tǒng)已經(jīng)為數(shù)據(jù)分頁了,下面就看看這次探討的關(guān)鍵問題分頁函數(shù)的定義
<% 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 %>
把上面這個(gè)分頁函數(shù)代碼COPY存成一個(gè)ASP文件,在需要使用的頁面里用include來引入他調(diào)用的時(shí)候只要 Call("/你調(diào)用的文件名?")就ok了,比如我的 news頁面里要調(diào)用那么就是<%Call("/news.asp?")%>
剛才我們所到這是有限制的意思就是說第一段代碼里除了sql查詢內(nèi)容和輸出內(nèi)容可以更改,其他的聲明記錄集的對(duì)象,page, pages, allpages這些變量都不能更改,否則將無法運(yùn)行~其實(shí)這個(gè)程序是無關(guān)緊要的,最主要的就是,這個(gè)分頁函數(shù)可以在任何一個(gè)asp葉面里調(diào)用。
相關(guān)文章
學(xué)習(xí)ASP和編程的28個(gè)觀點(diǎn)
學(xué)習(xí)ASP和編程的28個(gè)觀點(diǎn)...2007-02-02用javascript編寫asp應(yīng)用--第一課--通覽
用javascript編寫asp應(yīng)用--第一課--通覽...2007-03-03asp模板引擎終結(jié)者(WEB開發(fā)之ASP模式)
[紅色]asp模板引擎終結(jié)者(WEB開發(fā)之ASP模式)...2006-06-06用Asp如何實(shí)現(xiàn)防止網(wǎng)頁頻繁刷新?
用Asp如何實(shí)現(xiàn)防止網(wǎng)頁頻繁刷新?...2006-12-12asp 內(nèi)置對(duì)象 Application 詳解
asp 內(nèi)置對(duì)象 Application 詳解...2007-11-11