首页 | 站长免费中心 | 新手上路 | 网站运营 | 网页制作 | 图片设计 | 动画设计 | 网页编程 | 网页特效 | 本站专题 | 虚拟主机 | 域名注册 | 网站建设 | 程序下载
       免费空间资源 | 新闻咨询 | 免费域名 | 免费网盘 | 网站推广 | 网站策划 | 建站经验 | 网站优化 | 网页代码 | 源码下载 | 音乐小偷 | 网络赚钱 | 论坛交流
网站建设
网站建设
虚拟主机
虚拟主机
域名注册
域名注册
711网络首页
站长工具
站长工具
网站源码
网站源码
站长论坛
站长论坛

 711网络 网页编程ASP代码

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

来源: 互联网    日期:2006-5-16
 
长内容即可以手动分页也可以自动分页。
  采用自动分页功能,只需告诉计算机每页大约字数就可以了。
  下面附源码,方便自己,也方便大家研究:

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




更多的VB.Net 开发的长内容自动分页功能请到论坛查看: http://BBS.TC711.COM



【 双击滚屏 】 【 评论 】 【 收藏 】 【 打印 】 【 关闭 】 来源: 互联网    日期:2006-5-16   

发 表 评 论
查看评论

  您的大名:
  • 尊重网上道德,遵守中华人民共和国的各项有关法律法规
  • 承担一切因您的行为而直接或间接导致的民事或刑事法律责任
  • 本站管理人员有权保留或删除其管辖留言中的任意内容
  • 本站有权在网站内转载或引用您的评论
  • 参与本评论即表明您已经阅读并接受上述条款
认证编码: 刷新验证码
点评内容: 字数0
  精品推荐  
  本月推荐  
  友情赞助  

关于我们 | 联系我们 | 广告投放 | 留言反馈 | 免费程序 | 虚拟主机 | 网站建设 |  网站推广 |  google_sitemap baidu_sitemap RSS订阅
本站所有资源均来自互联网,如有侵犯您的版权或其他问题,请通知管理员,我们会在最短的时间回复您
Copyright © 2005-2015 Tc711.Com All Rights Reserved 版权所有·711网络   蜀ICP备05021915号
110网监备案 信息产业备案 不良信息举报