<%
''文件名稱:page.inc
''功能:處理數據翻頁的函數
''作者:天地無用
Sub ShowPageBar(TotalPage,CurPage,strUrl)
''參數TotalPage:整個頁數
''參數CurPage:當前頁數
''參數strUrl:翻頁使用的連接地址
DIM strPage
CurPage=GetValidPageNO(TotalPage,CurPage)
Response.Write "<TABLE WIDTH=''100%''>"
Response.Write "<TR><td width=''100%'' align=''right''>"
Response.Write "頁數:" & CurPage & "/" & TotalPage & " "
IF InSTR(strUrl,"?")=0 THEN
strPage="?Page="
ELSE
strPage="&Page="
END IF
IF Curpage>1 THEN
Response.Write "<a href=" & strUrl &strPage&"1>第一頁</a>|"
ELSE
Response.Write "第一頁|"
END IF
IF CurPage>=2 THEN
Response.Write "<a href=" & strUrl & strPage &CurPage-1&">上一頁</a>|"
ELSE
Response.Write "上一頁|"
END IF
IF cInt(CurPage)<cInt(TotalPage) THEN
Response.Write "<a href=" & strUrl & strPage &CurPage+1&">下一頁</a>|"
ELSE
Response.Write "下一頁|"
END IF
IF cInt(CurPage) <>cInt(TotalPage) THEN
Response.Write "<a href=" & strUrl & strPage & TotalPage&">最后一頁</a>"
ELSE
Response.Write "最后一頁"
END IF
Response.Write "</TD></tr></table>"
END SUB
Function GetValidPageNo(PageCount,CurPage)
Dim iPage
iPage=CurPage
IF cInt(CurPage)<1 THEN
iPage= 1
END IF
IF cInt(iPage) > cInt(PageCount) THEN
iPage= PageCount
END IF
GetValidPageNo=iPage
END Function
%>
下面是使用這個函數的例子,文件名稱是showinfo.asp
<!--#include Virtual="page.inc"-->
<%
SET objConn=Server.CreateObject("ADODB.CONNECTION")
SET objRst=Server.CreateObject("ADODB.RECORDSET")
objConn.Open APPLICATION("dsn")
strSQL="SELECT * FROM ********"
''這里是你要使用的查詢
objRst.Open strSQL,objConn,adOpenStatic
’打開數據記錄
objRst.PageSize=50
’設置單頁的數據記錄數
iPageCount=objRst.PageCount
’定義了一個頁碼數量的變量
If Len(Request.QueryString("Page"))=0 Then
CurPage=1
Else
CurPage=CInt(Request.Querystring("Page"))
End If
’得到當前的頁碼
objRst.AbsolutePage=CurPage
’設置記錄集中的當前頁
’開始調用顯示翻頁的函數
''顯示頁數欄
''函數原型:ShowPageBar(TotalPage,CurPage,strUrl)
strUrl="showinfo.asp"
''定義連接的URL,這里完全可以用自己的頁面地址,只用一頁就可以完成翻頁的功能了!
ShowPageBar iPageCount,CurPage,strUrl
''調用完成
************************
這里顯示自己的內容
************************
objConn.Close
SET objRst=NOTHING
SET objConn=NOTHING
%>
歡迎大家使用,如果有建議或者意見請同我聯系,大家一起討論。