ASP经典分页类
程序员文章站
2023-11-29 18:23:22
asp经典分页类 出处 '=====================================...
asp经典分页类
出处
'=====================================================================
'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
出处
'=====================================================================
'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