分享
 
 
 

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

王朝vb·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

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

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

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

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, ByVal 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

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有