分页函数

<%

'***********************************************
'函数名:JoinChar
'作  用:向地址中加入 ? 或 &
'参  数:strUrl  ----网址
'返回值:加了 ? 或 & 的网址
'***********************************************
function JoinChar(strUrl)
 if strUrl="" then
  JoinChar=""
  exit function
 end if
 if InStr(strUrl,"?")<len(strUrl) then
  if InStr(strUrl,"?")>1 then
   if InStr(strUrl,"&")<len(strUrl) then
    JoinChar=strUrl & "&"
   else
    JoinChar=strUrl
   end if
  else
   JoinChar=strUrl & "?"
  end if
 else
  JoinChar=strUrl
 end if
end function

'**************************************************
'过程名:showpage
'作  用:显示“上一页 下一页”等信息
'参  数:sfilename  ----链接地址
'       totalnumber ----总数量
'       maxperpage  ----每页数量
'       ShowTotal   ----是否显示总数量
'       ShowAllPages ---是否用下拉列表显示所有页面以供跳转。有某些页面不能使用,否则会出现JS错误。
'       strUnit     ----计数单位
'**************************************************
sub showpage(sfilename,totalnumber,maxperpage,ShowTotal,ShowAllPages,strUnit)
 dim n, i,strTemp,strUrl
 if totalnumber mod maxperpage=0 then
     n= totalnumber / maxperpage
   else
     n= totalnumber / maxperpage+1
   end if
   strTemp= "<table align='center'><tr><td><font size='2'>"
 if ShowTotal=true then
  strTemp=strTemp & "共 <b>" & totalnumber & "</b> " & strUnit & "&nbsp;&nbsp;"
 end if
 strUrl=JoinChar(sfilename)
   if CurrentPage<2 then
      strTemp=strTemp & "首页 上一页&nbsp;"
   else
      strTemp=strTemp & "<a href='" & strUrl & "page=1'>首页</a>&nbsp;"
      strTemp=strTemp & "<a href='" & strUrl & "page=" & (CurrentPage-1) & "'>上一页</a>&nbsp;"
   end if

   if n-currentpage<1 then
      strTemp=strTemp & "下一页 尾页"
   else
      strTemp=strTemp & "<a href='" & strUrl & "page=" & (CurrentPage+1) & "'>下一页</a>&nbsp;"
      strTemp=strTemp & "<a href='" & strUrl & "page=" & n & "'>尾页</a>"
   end if
    strTemp=strTemp & "&nbsp;页次:<strong><font color=red>" & CurrentPage & "</font>/" & n & "</strong>页 "
    strTemp=strTemp & "&nbsp;<b>" & maxperpage & "</b>" & strUnit & "/页"
 if ShowAllPages=True then
  strTemp=strTemp & "&nbsp;转到:<select name='page' size='1' οnchange=""javascript:window.location='" & strUrl & "page=" & "'+this.options[this.selectedIndex].value;"">"  
     for i = 1 to n  
      strTemp=strTemp & "<option value='" & i & "'"
   if cint(CurrentPage)=cint(i) then strTemp=strTemp & " selected "
   strTemp=strTemp & ">第" & i & "页</option>"  
     next
  strTemp=strTemp & "</select>"
 end if
 strTemp=strTemp & "</font></td></tr></table>"
 response.write strTemp
end sub

%>

 

列表页面的代码

<%
const MaxPerPage=15
dim totalPut,CurrentPage,TotalPages
dim strFileName
dim strEmplName
strEmplName = strReplace(request("emplName"))

strFileName="employeeList.asp?emplName="&strEmplName&""
if request("page")<>"" then
    CurrentPage=cint(request("page"))
else
 CurrentPage=1
end if
%>

<form name="form1" method="post" action="">

用户名:<input name="emplName" type="text" class="myinput" id="emplName">

<input name="Submit" type="submit" class="mybutton" value="提交">

</form>

<table width="100%" border="1" cellspacing="1" cellpadding="5" id="bgtable">
  <tr>
    <td colspan="6" align="center" id="bgtitle">员工列表</td>
  </tr>
  <tr>
    <td width="13%" align="center" id="bgtitle">用户名</td>
    <td width="13%" align="center" id="bgtitle">姓名</td>
    <td width="20%" align="center" id="bgtitle">所属部门</td>
  </tr>

<%
sql = "select * from admin_employee where flag <> 1"

if strEmplName = "" then
  sql = sql
else
  sql = sql&" and userName like '%"&strEmplName&"%'"
end if

rs.open sql,conn,1,1
if not(rs.bof and rs.eof) then

   totalPut=rs.recordcount
  if currentpage<1 then
         currentpage=1
     end if
     if (currentpage-1)*MaxPerPage>totalput then
      if (totalPut mod MaxPerPage)=0 then
        currentpage= totalPut / MaxPerPage
     else
         currentpage= totalPut / MaxPerPage + 1
      end if

     end if
  if currentPage=1 then
         showContent
         showpage strFileName,totalput,MaxPerPage,true,true,""
      else
          if (currentPage-1)*MaxPerPage<totalPut then
              rs.move  (currentPage-1)*MaxPerPage
           dim bookmark
             bookmark=rs.bookmark
             showContent
             showpage strFileName,totalput,MaxPerPage,true,true,""
         else
          currentPage=1
             showContent
             showpage strFileName,totalput,MaxPerPage,true,true,""
      end if
  end if
    rs.Close
 sub showContent()
    dim i
    i=0
    do while not rs.eof
%>

<tr>
    <td align="center" id="bkbody"><%=rs("userName")%></td>
    <td align="center" id="bkbody"><%=rs("realName")%></td>
    <td align="center" id="bkbody"><%=rs("deptName")%></td>

</td>
  </tr>
<%
 i=i+1
 if i>=MaxPerPage then exit do
 rs.MoveNext
    loop
end sub
else
%>
  <tr>
    <td colspan="6" align="center" id="bkbody">暂时还没有员工信息!</td>
  </tr>
<%
end if
%>
</table>

 

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值