欢迎光临
我们一直在努力

ASP经典分页类-ASP教程,ASP技巧

建站超值云服务器,限时71元/月

=====================================================================

xdownpage asp版本

版本 1.00

code by zykj2000

email: zykj_2000@163.net

bbs: http://bbs.513soft.net

本程序可以免费使用、修改,希望我的程序能为您的工作带来方便

但请保留以上请息

程序特点

本程序主要是对数据分页的部分进行了封装,而数据显示部份完全由用户自定义,

支持url多个参数

使用说明

程序参数说明

papgesize 定义分页每一页的记录数

getrs 返回经过分页的recordset此属性只读

getconn 得到数据库连接

getsql 得到查询语句

程序方法说明

showpage 显示分页导航条,唯一的公用方法

例:

包含文件

set mypage=new xdownpage 创建对象

mypage.getconn=conn 得到数据库连接

mypage.getsql="select * from productinfo order by id asc"

mypage.pagesize=5 设置每一页的记录条数据为5条

set rs=mypage.getrs() 返回recordset

mypage.showpage() 显示分页信息,这个方法可以,在set rs=mypage.getrs()以后

任意位置调用,可以调用多次

for i=1 to mypage.pagesize 接下来的操作就和操作一个普通recordset对象一样操作

if not rs.eof then 这个标记是为了防止最后一页的溢出

response.write rs(0) & "

" 这里就可以自定义显示方式了

rs.movenext

else

exit for

end if

next

=====================================================================

const btn_first="9" 定义第一页按钮显示样式

const btn_prev="3" 定义前一页按钮显示样式

const btn_next="4" 定义下一页按钮显示样式

const btn_last=":" 定义最后一页按钮显示样式

const xd_align="center" 定义分页信息对齐方式

const xd_width="100%" 定义分页信息框大小

const xd_height="20"

class xdownpage

private xd_pagecount,xd_conn,xd_rs,xd_sql,xd_pagesize,str_errors,int_curpage,str_url,int_totalpage,int_totalrecord

=================================================================

pagesize 属性

设置每一页的分页大小

=================================================================

public property let pagesize(int_pagesize)

if isnumeric(int_pagesize) then

xd_pagesize=clng(int_pagesize)

else

str_error=str_error & "pagesize的参数不正确"

showerror()

end if

end property

public property get pagesize

if xd_pagesize="" or (not(isnumeric(xd_pagesize))) then

pagesize=10

else

pagesize=xd_pagesize

end if

end property

=================================================================

getrs 属性

返回分页后的记录集

=================================================================

public property get getrs()

set xd_rs=server.createobject("adodb.recordset")

xd_rs.pagesize=pagesize

xd_rs.open xd_sql,xd_conn,1,1

if not(xd_rs.eof and xd_rs.bof) then

if int_curpage>xd_rs.pagecount then

int_curpage=xd_rs.pagecount

end if

xd_rs.absolutepage=int_curpage

end if

set getrs=xd_rs

end property

================================================================

getconn 得到数据库连接

================================================================

public property let getconn(obj_conn)

set xd_conn=obj_conn

end property

================================================================

getsql 得到查询语句

================================================================

public property let getsql(str_sql)

xd_sql=str_sql

end property

==================================================================

class_initialize 类的初始化

初始化当前页的值

==================================================================

private sub class_initialize

========================

设定一些参数的黙认值

========================

xd_pagesize=10 设定分页的默认值为10

========================

获取当前面的值

========================

if request("page")="" then

int_curpage=1

elseif not(isnumeric(request("page"))) then

int_curpage=1

elseif cint(trim(request("page")))<1 then

int_curpage=1

else

int_curpage=cint(trim(request("page")))

end if

end sub

====================================================================

showpage 创建分页导航条

有首页、前一页、下一页、末页、还有数字导航

====================================================================

public sub showpage()

dim str_tmp

int_totalrecord=xd_rs.recordcount

if int_totalrecord<=0 then

str_error=str_error & "总记录数为零,请输入数据"

call showerror()

end if

if int_totalrecord int_totalpage=1

else

if int_totalrecord mod pagesize =0 then

int_totalpage = int(int_totalrecord / xd_pagesize * -1)*-1

else

int_totalpage = int((int_totalrecord / xd_pagesize * -1)*-1)+1

end if

end if

if int_curpage>int_totalpage then

int_curpage=int_totalpage

end if

===============================================================================

显示分页信息,各个模块根据自己要求更改显求位置

===============================================================================

response.write " "

str_tmp=showfirstprv

response.write str_tmp

str_tmp=shownumbtn

response.write str_tmp

str_tmp=shownextlast

response.write str_tmp

str_tmp=showpageinfo

response.write str_tmp

response.write " "

showgoto

response.write "

"

end sub

====================================================================

showfirstprv 显示首页、前一页

====================================================================

private function showfirstprv()

dim str_tmp,int_prvpage

if int_curpage=1 then

str_tmp=btn_first&" "&btn_prev

else

int_prvpage=int_curpage-1

str_tmp=""&btn_first&" "& btn_prev&""

end if

showfirstprv=str_tmp

end function

====================================================================

shownextlast 下一页、末页

====================================================================

private function shownextlast()

dim str_tmp,int_nextpage

if int_curpage>=int_totalpage then

str_tmp=btn_next & " " & btn_last

else

int_nextpage=int_curpage+1

str_tmp=""&btn_next&" "& btn_last&""

end if

shownextlast=str_tmp

end function

====================================================================

shownumbtn 数字导航

====================================================================

private function shownumbtn()

dim i,str_tmp

for i=1 to int_totalpage

str_tmp=str_tmp & "["&i&"] "

next

shownumbtn=str_tmp

end function

====================================================================

shownumbtn 修改后的数字导航

====================================================================

function shownumbtn()

dim i,str_tmp,end_page,start_page

if int_curpage>4 then

if int_curpage+2 start_page=int_curpage-2

end_page=int_curpage+2

else

start_page=int_totalpage-4

end_page=int_totalpage

end if

else

start_page=1

if int_totalpage>5 then

end_page=5

else

end_page=int_totalpage

end if

end if

for i=start_page to end_page

str_tmp=str_tmp & " ["&i&"] "

next

shownumbtn=str_tmp

end function

====================================================================

showgoto 页面跳转

====================================================================

private function showgoto()

dim m_item

========================================================

将返回的url参数逐个的写入隐藏域中,以便与参数继续传递

========================================================

for each m_item in request.querystring

if instr("page",m_item)=0 then 从参数中除去 "page" 的值

response.write ""

end if

next

========================================================

response.write " 转到第:"

response.write " 页 "

end function

====================================================================

showpageinfo 分页信息

更据要求自行修改

====================================================================

private function showpageinfo()

dim str_tmp

str_tmp=" [页次:"&int_curpage&"/"&int_totalpage&"页] [共"&int_totalrecord&"条] ["&xd_pagesize&"条/页]"

showpageinfo=str_tmp

end function

====================================================================

修改后的获取当前url参数的函数

codeing by redsun

====================================================================

private function geturl()

dim scriptaddress, m_itemurl, m_item

scriptaddress = cstr(request.servervariables("script_name"))&"?"取得当前地址

if (request.querystring <> "") then

m_itemurl = ""

for each m_item in request.querystring

if instr("page",m_item)=0 then

m_itemurl = m_itemurl & m_item &"="& server.urlencode(request.querystring(""&m_item&"")) & "&"

end if

next

scriptaddress = scriptaddress & m_itemurl取得带参数地址

end if

geturl = scriptaddress & "page="

end function

====================================================================

设置 terminate 事件。

====================================================================

private sub class_terminate

xd_rs.close

set xd_rs=nothing

end sub

====================================================================

showerror 错误提示

====================================================================

private sub showerror()

if str_error <> "" then

response.write("

" & sw_error & "")

response.end

end if

end sub

end class

赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » ASP经典分页类-ASP教程,ASP技巧
分享到: 更多 (0)

相关推荐

  • 暂无文章