频 道 直 达 - 新闻 - 读书 - 培训 - 教程 - 前沿 - 组网 - 系统应用 - 安全 - 编程 - 存储 - 操作系统 - 数据库 - 服务器 - 专题 - 产品 - 案例库 - 技术圈 - 博客 - BBS
51CTO.COM_中国领先的IT技术网站
找资料:

VB.Net开发的长内容自动分页功能

作者: 出处:AcNow.Net  (  ) 砖  (  ) 好  评论 ( ) 条  进入论坛
更新时间:2006-12-08 00:55
关 键 词:.NET  VB  分页
阅读提示:长内容即可以手动分页也可以自动分页。采用自动分页功能,只需告诉计算机每页大约字数就可以了。下面附源码,供大家参考!

长内容即可以手动分页也可以自动分页。

采用自动分页功能,只需告诉计算机每页大约字数就可以了。

下面附源码,方便自己,也方便大家研究:

Public Class WebForm1
Inherits System.Web.UI.Page
Protected WithEvents Label1 As System.Web.UI.WebControls.Label
Protected WithEvents Label2 As System.Web.UI.WebControls.Label
Protected WithEvents Label3 As System.Web.UI.WebControls.Label
Protected WithEvents Label4 As System.Web.UI.WebControls.Label

#Region " Web 窗体设计器生成的代码 "

''该调用是 Web 窗体设计器所必需的。
<System.Diagnostics.DebuggerStepThrough()> Private Sub InitializeComponent()

End Sub

Private Sub Page_Init(ByVal sender As System.Object,

al e As System.EventArgs) Handles MyBase.Init
''CODEGEN: 此方法调用是 Web 窗体设计器所必需的
''不要使用代码编辑器修改它。
InitializeComponent()
End Sub

#End Region

Private Sub Page_Load(ByVal sender As System.Object,

ByVal e As System.EventArgs) Handles MyBase.Load
''在此处放置初始化页的用户代码
pages()
End Sub

''长内容分页
Sub pages()
Dim i, start, stops, t, stat, statt, pp, pagecount, pagesize, articleid As Integer
Dim pa, articletxt, articletext, contenttext, html As String
contenttext = "<p>aaaaaaa</p><p>bbbbbbbbbbbb</p><p>cccccccccccccccc</p>"
''变量初始值
stat = 0
statt = 0
start = 0 ''开始查询的字符串位置,初始为0
stops = 0
pagesize = 2 ''定义每页至少显示字符串数
pagecount = 0

''获得当前的页数
pa = Request.Params("page")
If (pa = "" Or IsDBNull(pa)) Then
pa = "1"
End If
pp = Convert.ToInt32(pa)

''获得内容
articletxt = contenttext

''判断页面的内容长度是否大于定义的每页至少显示字符串数
If (articletxt.Length >= pagesize) Then '' 如果大于字符串数,则我们可以分页显示
t = articletxt.Length / pagesize ''获得大致的总页数
''根据目前获得的页数循环
For i = 0 To t
''如果查询开始位置到查询的范围超出整个内容的长度,那么就不用寻找断点(分页点);反之,查找
If (start + pagesize < articletxt.Length) Then
stat = articletxt.IndexOf("</p>", start + pagesize) ''查找</P>分页点的位置
''如果找不到
''If (stat <= 0) Then
''stat = articletxt.IndexOf("</p>", start + pagesize) ''查找</p>分页点的位置;

这里您可以自己设置分页点的判断
''End If
End If
''Response.Write("''" & stat & "''")
If (stat <= 0) Then
''如果找不到分页点,说明不能分页,也就不需要做其他的劳动了;否则,就进行分页
''articletext = articletxt ''将结果付给要导出的变量
''Label1.Text = articletext & stat
''Exit Sub
Else

stops = stat ''分页点的位置也就作为这一页的终点位置
If (start + pagesize >= articletxt.Length) Then ''如果起始位置到查询的范围超出整个内容的长度,

那么这一页的终点位置为内容的终点
stops = articletxt.Length
End If
If (pp = i + 1) Then ''如果是当前,那么输出当前页的内容
articletext = articletxt.Substring(start, stops - start) ''

取内容的起始位置到终点位置这段字符串输出
Label1.Text = articletext
End If
start = stat ''将终点位置作为下一页的起始位置
pagecount = pagecount + 1 ''获得实际页总数
''Response.Write("-" & pagecount & "-")
End If
Next
End If
''分页部分(这里就简单多了)
''定义分页代码变量

If (pagecount > 1) Then ''当页数大于1的时候我们显示页数
''Response.Write(pp)

If (pp - 1 > 0) Then ''显示上一页,方便浏览
html += "<a href=?id=" & articleid & "&page=" & (pp - 1) & ">[上一页]</a> "
Else
If pp = 1 Then
html += "[<font color=#cccccc>上一页</font>] "
Else
html += "<a href=?id=" & articleid & "&page=" & (1) & ">[上一页]</a> "
End If

End If
For i = 1 To pagecount

If (i = pp) Then ''如果是当前页,加粗显示
html += "<b>[" & i & "]</b> "
Else
html += "<a href=?id=" & articleid & "&page=" & i & ">[" & i & "]</a> "
End If
Next
If (pp + 1 > pagecount) Then ''显示下一页,方便浏览
If pp = pagecount Then
html += "[<font color=#cccccc>下一页</font>] "
Else
html += "<a href=?id=" & articleid & "&page=" & (pagecount) & ">[下一页]</a></p>"
End If
Else
html += "<a href=?id=" & articleid & "&page=" & (pp + 1) & ">[下一页]</a></p>"
End If
End If
Label2.Text = html
End Sub

End Class

(责任编辑 火凤凰 sunsj@51cto.com  TEL:(010)68476636-8007)


发表
查看
我也说两句

匿名发表

(如果看不清请点击图片进行更换)


中 国 领 先 的 IT 技 术 网 站 ·
技 术 成 就 梦 想
·Java基础教程 (查看52473次)
·UML类图详解 (查看46951次)
·Java编程开发手册 (查看25172次)
·UML统一建模语言 (查看24155次)
·C#技术开发指南 (查看22515次)
·Java编程开发手册 (1195个砖)
·Java基础教程 (429个砖)
·C#技术开发指南 (304个砖)
·PB开发教程 (220个砖)
·.NET开发手册 (217个砖)
·Java编程开发手册 (653个好)
·Java基础教程 (569个好)
·.NET开发手册 (251个好)
·PB开发教程 (209个好)
·Delphi开发技术手册 (174个好)
订阅技术快讯
电子杂志下载
名称:网络安全精品应用黄皮书
简介:《2007精品网络安全黄皮书》包括了9个大类24个小类, 800余篇文章,内容包含了熊猫烧香病毒、DDOS攻击、ARP病等热点问题的介绍及解决方案。从病毒查杀、防范、系统、数据等各方面的安全设置到黑客技术的了解、防范,涉及到了安全应用的全部领域, 由浅至深内容全面。
名称:Vista精品应用黄皮书
简介:《Vista精品应用黄皮书》囊括了Vista的各方面内容。此次的精简版,是将里面的内容做了提取,便于用户下载和使用。内容包含了各种Vista的安装与实施、技巧与解析以及各种Vista相关学习文档和相关软件的安全下载。该电子书是了解和应用Vista人员必备的工具手册,并且也是第一本
名称:2006中国IT论坛精品集合
简介:本书由“51CTO论坛推广联盟”制作完成。书中所有内容均来自各联盟成员的论坛(网站)。制作本书的目的是为了集中大家的优势资源,将更多更精彩的内容带给广大技术爱好者。本书是联盟成立以来制作的第一本书。
关键字阅读
频道精选
主编信箱 热线:010-66476606 告诉我们您想看的:专题 文章
关于我们 | 诚聘英才 | 联系我们 | 网站大事 | 意见反馈 | 网站地图
Copyright©2005-2007 51CTO.COM 版权所有