当前位置:首页 > 网络编程 > WEB编程 > ASP > ASP基础实例教程之两个小时学会asp分页技术二

ASP基础实例教程之两个小时学会asp分页技术二

点击次数:27 次 发布日期:2008-12-01 17:05:27 作者:源代码网
源代码网推荐 (第2个小时)
建立好数据库后。。。我们首先要把数据库里的信息给输出来。。。
显示数据库信息我们在五个小时学会Asp连接access添加,删除,修改的第2个小时里面有详细解说
如果有什么不明白的就重新复习一下。。。
(一)首先有必要和大家详细说一下recordset对象的成员。。有关分页技术的几个成员我在这里
详细解说一下。
Pagesize属性:指示Recordset中一页所包含的记录数。默认值为10
  Pagecount属性:指示Recordset对象包含的数据页数
AbsolutePage属性:指示从1到Recordset对象所含页数的长整型。通俗的说就是如果数据库有
              4页。那么 AbsolutePage就是1,2,3,4

大家看了后会有点迷惑。。不要怕。。下面就用事例来解说。。

(二)用DW建立文件保存为fenye.asp
代码如下:
CODE:

<!--#include file="conn.asp"-->
<%
set rs=server.createobject("adodb.recordset")
exec="select * from aa order by id desc"
rs.open exec,conn,1,1
%>
<%
  rs.pagesize=2
  pagecount=rs.pagecount
  page=int(request("page"))
  if page<=0 then page=1
  if request.QueryString("page")="" then
  page=1
  end if
  rs.absolutepage=page
%>
<%
    for i=1 to rs.PageSize
    if rs.EOF then
    exit for
    end if
%>
<br><tr>
  <td><%=rs("title")%></td>
  </tr>
</br>
<%
  rs.movenext
  next
%>
<%
rs.close
set bb=nothing
%>
</body></table><% for i=1 to pagecount %>
<a href="yemian.asp?page=<%=i%>"><%=i%></a>
<%next%>
 


代码解释:
(1)   <!--#include file="conn.asp"--> 调用conn.asp

(2)
<%
set rs=server.createobject("adodb.recordset")
exec="select * from aa order by id desc"
rs.open exec,conn,1,1
%>
上面的代码是创建一个recordset对象。。该对象是用来打开数据库中的表的。。也就是打开aa
exec="select * from aa order by id desc " 这句的意思是查找表aa中所有信息并倒序排列
信息. *号表示aa中所有的信息 order by id 就是aa中id字段 desc 是倒序的意思
rs.open exec,conn,1,1 这句话的意思是用recordset对象来打开conn中的表

(3)
<%
  rs.pagesize=2
  pagecount=rs.pagecount
  page=int(request("page"))
  if page<=0 then page=1
  if request.QueryString("page")="" then
  page=1
  end if
  rs.absolutepage=page
%>
这段代码相当重要。大家觉的里面有些单词很熟悉是不是。。
rs.这个的意思是前面 rs=server.createobject("adodb.recordset")
rs就是recordset对象
在很多语言中。rs.的逗号的中文意思是“的”。
那么rs.的解释就是 recordset对象的
rs.pagesize=2 中文解释就是recordset对象的pagesize等于2 pagesize的意思是一页显示多少条信息

pagecount=rs.pagecount 定义pagecount等于recordset对象的pagecount

page=int(request("page")) 接收到的page是整数型

if page<=0 then page=1 如果page小于等于0 page就等于1
if request.QueryString("page")="" then 如果接收到的page是空。
page=1   page等于1
end if   结束

rs.absolutepage=page recordset对象的absolutepage等于page

我只是把每一句语句的意思解释了一遍。。
这里每一句语句都和其它语句有关联。。看不懂也不要泄气。。
因为这个东西是不能一下子学会的。。要看上一段时间。。慢慢理解。。
(4)
<%
    for i=1 to rs.PageSize
    if rs.EOF then
    exit for
    end if
%>
上面语句是循环语句。。实现数据库信息的输出
for i=1 to rs.PageSize 每次输出两条信息。PageSize 在前面已经定义为2
if rs.EOF then 如果扫描到数据表中最后一条就结束 exit for

<%
  rs.movenext
  next
%>
这句是和上面的for语句承接的。。 rs.movenext 游标指向下一个数据next

(5)
</body></table><% for i=1 to pagecount %>
<a href="yemian.asp?page=<%=i%>"><%=i%></a>
<%next%>
这句语句的作用是显示页数。。就是显示1,2,3,4 。。我们点2就跳到第2页的内容

这段语句用到了之前定义的pagecount=rs.pagecount 指示Recordset对象包含的数据页数
也就是pagecount能记录数据表的数据分成了几页
<% for i=1 to pagecount %>那么这句的意思是显示1,2,3,4。。。。
<a href="yemian.asp?page=<%=i%>"><%=i%></a>这句理解起来有点麻烦。。
?号是连接字符。fenye.asp?page是fenye.asp中的page 这里的page就是先前
定义的 page=int(request("page"))

<a href="fenye.asp?page=<%=i%>">整句的意思就是为每个显示的数字添加连接。。
<%=i%>这里是指1,2,3,4。。。所以我们点任意一个数字就会跳转到该页的内容
<%next%> 指向下一个

到这里全部学完了。。。分页技术有点复杂。。。
我只能把语句的意思解释一下。。要真正掌握还是要多多动手。。
多多思考。。那样才能明白。。。

源文件下

源代码网供稿.
网友评论 (0)
会员中心
网络编程
本站推荐
网络编程之精华