DATALIST分页---常用

本文介绍了一种使用 ASP.NET 实现新闻列表分页的方法。通过 SQL 查询获取新闻记录,并将其填充到 DataSet 中,再利用 DataList 控件进行展示。文章详细说明了如何计算总页数和当前页面的新闻条目,以及如何通过按钮和下拉列表来改变页面。

   Private Sub Page_Init(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Init
        'CODEGEN: 此方法调用是 Web 窗体设计器所必需的
        '不要使用代码编辑器修改它。
        InitializeComponent()
        BindList(1)
        PageListItem()
        ShowWhatButton()
    End Sub

        Sub BindList(ByVal PageNo As Integer)

       myconn = New SqlClient.SqlConnection
        myconn.ConnectionString = (xinxi.stringconnection)
        Dim strSQL As String = "Select * From news  Order By newsid Desc "
        Dim objCmd As New SqlClient.SqlDataAdapter(strSQL, myconn.ConnectionString)
        Dim DS As New DataSet
        objCmd.Fill(DS, "news")
        Dim myTable As DataTable = DS.Tables("news")

        Dim TotalRecord As Integer = myTable.Rows.Count
        ShowTotalRecord.Text = TotalRecord


        Dim TotalPage As Integer          
        If TotalRecord < 20 Then         ‘20:每页显示的数量
            TotalPage = 1
        Else
            If TotalRecord Mod 20 <> 0 Then
                TotalPage = TotalRecord / 20 + 1
            Else
                TotalPage = TotalRecord / 20
            End If
        End If
        ShowTotalPage.Text = TotalPage


        Dim tempTable As DataTable = myTable.Clone()

        Dim I, J As Integer
        For I = (PageNo - 1) * 20 To PageNo * 20 - 1
            If I > myTable.Rows.Count - 1 Then Exit For
            Dim newRow As DataRow = tempTable.NewRow()
            For J = 0 To myTable.Columns.Count - 1
                newRow(myTable.Columns(J).ColumnName) = myTable.Rows(I).Item(J)
            Next
            tempTable.Rows.Add(newRow)
        Next
        Label1.Text = PageNo
        myGuestbook.DataSource = tempTable
        myGuestbook.DataBind()
    End Sub

    Sub ShowWhatButton()
        If PageList.SelectedIndex = 0 Then
            firstButton.Enabled = False

            preButton.Enabled = False
        Else
            firstButton.Enabled = True
            preButton.Enabled = True
        End If
        If PageList.SelectedIndex = PageList.Items.Count - 1 Then
            nextButton.Enabled = False
            lastButton.Enabled = False
        Else
            nextButton.Enabled = True
            lastButton.Enabled = True
        End If
    End Sub
    Sub PageListItem()
        Dim I As Integer
        PageList.Items.Clear()
        For I = 0 To ShowTotalPage.Text - 1
            PageList.Items.Add("第" & I + 1 & "页")
        Next
    End Sub


    Sub PageList_Change(ByVal sender As Object, ByVal e As EventArgs)
        BindList(PageList.SelectedIndex + 1)

        ShowWhatButton()
    End Sub


    Sub PageChange(ByVal sender As Object, ByVal e As CommandEventArgs)
        Select Case e.CommandArgument
            Case "firstPage"
                PageList.SelectedIndex = 0
            Case "prePage"
                PageList.SelectedIndex -= 1
            Case "nextPage"
                PageList.SelectedIndex += 1
            Case "lastPage"
                PageList.SelectedIndex = ShowTotalPage.Text - 1

        End Select
        BindList(PageList.SelectedIndex + 1)
        ShowWhatButton()
    End Sub 

 

<table height="450" cellSpacing="0" cellPadding="0" width="600" align="center" border="0">
 <TBODY>
  <tr>
   <td vAlign="top"><ASP:DATALIST id="myGuestbook" Runat="Server">
     <HeaderTemplate>
     </HeaderTemplate>
     <ItemTemplate>
      <table cellpadding="0" cellspacing="0" border="0" width="100%">
       <tr>
        <td Width="10%"></td>
        <td>
         <table>
          <tr>
           <td><Img Src="images/jiantou.jpg"></td>
           <td width="350"><A class=style5 Href='xinwen.aspx?newsid=<%# Container.DataItem("newsid")%>'><%# Container.DataItem("newsname") %></A>
           </td>
           <td width="100" align="right"><%# DataBinder.Eval(Container.DataItem,"adddate","{0:d}")%>
           </td>
          </tr>
         </table>
        </td>
       </tr>
      </table>
     </ItemTemplate>
     <FooterTemplate>
     </FooterTemplate>
    </ASP:DATAL>
    <HR>
    <CENTER><BR>
     共<ASP:LABEL id="ShowTotalRecord" Runat="Server" ForeColor="Red"></ASP:LABEL>条新闻&nbsp;
     <asp:LinkButton id="firstButton" Runat="Server" OnCommand="PageChange" CommandArgument="firstPage"
      ForeColor="Black">首页</asp:LinkButton>
     &nbsp;
     <asp:LinkButton id="preButton" ForeColor="Black" Runat="Server" OnCommand="PageChange" CommandArgument="prePage">上一页</asp:LinkButton>&nbsp;
     <asp:LinkButton id="nextButton" ForeColor="Black" Runat="Server" OnCommand="PageChange" CommandArgument="nextPage">下一页</asp:LinkButton>&nbsp;
     <asp:LinkButton id="lastButton" ForeColor="Black" Runat="Server" OnCommand="PageChange" CommandArgument="lastPage">尾页</asp:LinkButton>&nbsp;
     页次:
     <asp:label id="Label1" runat="server" ForeColor="Red"></asp:label>/<ASP:LABEL id="ShowTotalPage" Runat="Server"></ASP:LABEL>页
     &nbsp;转到:<ASP:DROPDOWNLIST id="PageList" Runat="Server" OnSelectedIndexChanged="PageList_Change" AutoPostBack="True"></ASP:DROPDOWNLIST>
    </CENTER>
   </td>
  </tr>
 </TBODY>
</table>

根据原作 https://pan.quark.cn/s/0ed355622f0f 的源码改编 野火IM解决方案 野火IM是专业级即时通讯实时音视频整体解决方案,由北京野火无限网络科技有限公司维护支持。 主要特性有:私有部署安全可靠,性能强大,功能齐全,全平台支持,开源率高,部署运维简单,二次开发友好,方便与第三方系统对接或者嵌入现有系统中。 详细情况请参考在线文档。 主要包括一下项目: 野火IM Vue Electron Demo,演示如何将野火IM的能力集成到Vue Electron项目。 前置说明 本项目所使用的是需要付费的,价格请参考费用详情 支持试用,具体请看试用说明 本项目默认只能连接到官方服务,购买或申请试用之后,替换,即可连到自行部署的服务 分支说明 :基于开发,是未来的开发重心 :基于开发,进入维护模式,不再开发新功能,鉴于已经终止支持且不再维护,建议客户升级到版本 环境依赖 mac系统 最新版本的Xcode nodejs v18.19.0 npm v10.2.3 python 2.7.x git npm install -g node-gyp@8.3.0 windows系统 nodejs v18.19.0 python 2.7.x git npm 6.14.15 npm install --global --vs2019 --production windows-build-tools 本步安装windows开发环境的安装内容较多,如果网络情况不好可能需要等较长时间,选择早上网络较好时安装是个好的选择 或参考手动安装 windows-build-tools进行安装 npm install -g node-gyp@8.3.0 linux系统 nodej...
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值