Class CPaging Public RS ' RecordSet對象 Public Mark ' 指針標簽 Private sSize ' 每頁顯示數 Private sTotal ' 總記錄數 Private sPage ' 當前頁碼 Private sCount ' 總頁碼 Private Sub Class_Initialize sSize = 20 sPage = 1 sCount = 1 End Sub Private Sub Class_Terminate Closeobj RS End Sub '每頁顯示數 Property Let Size(Value) sSize = Value End Property Property Get Size Size = sSize End Property '當前頁碼 Property Let Page(Value) If Not IsNumeric(Value) Then sPage = 1 Else sPage = Value End If End Property Property Get Page If (sPage - 1) * sSize > sTotal Then If sTotal Mod sSize = 0 Then Page = Total \ sSize Else Page = Total \ sSize +1 End If ElseIf sPage 1 Then Page = 1 Else Page = sPage End If End Property '總頁碼 Property Get Count If sTotal Mod sSize = 0 Then Count = sTotal \ sSize Else Count = sTotal \ sSize + 1 End If End Property '總記錄數 Property Get Total() Total = sTotal End Property Public Function Open(Byval SQLString) Try DB.Openquery(RS,SQLString) sTotal = RS.RecordCount End Function End Class
以下是調用頁
復制代碼 代碼如下:
Dim Products Set Products = New CPaging With Products .Size = 15 '每頁顯示數 .Page = PageNum '當前頁 End With Try Products.Open(ListSQL) If Products.RS.Bof and Products.RS.Eof then Response.Write("TR>TD colspan=8>查找無記錄/TD>/TR>") Else Dim i i = 0 Products.RS.Move (Products.Page - 1) * Products.Size Do While Not Products.RS.Eof Response.Write("TR onmouseup=MouseUp(this); onmousedown=MouseDown(this); onmouseover=MouseOver(this); onclick=Click(this); onmouseout=MouseOut(this);>"vbCrLf) Response.Write("TD align=middle nowrap>" Products.RS("ProductsClassName") "/TD>"vbCrLf) Response.Write("TD align=left nowrap>" Products.RS("ProductsName") " /TD>"vbCrLf) Response.Write("/TR>"vbCrLf) i=i+1 If i >= Products.Size Then Exit Do Products.RS.MoveNext Loop End If