repeater留言板[轉]

来源:http://www.cnblogs.com/xiaz/archive/2016/04/21/5418894.html
-Advertisement-
Play Games

做了一個網站,其中的線上留言板塊是用Repeater來顯示留言的,這樣可以用少的代碼還實現多的功能,但是不知道怎麼分頁,要是留言過多就會使頁面變的很長,能過查看眾多網友的經驗,知道用PagedDataSource來實現。 Repeater分頁,需要依靠PagedDataSource。這個類存在於Sy ...


做了一個網站,其中的線上留言板塊是用Repeater來顯示留言的,這樣可以用少的代碼還實現多的功能,但是不知道怎麼分頁,要是留言過多就會使頁面變的很長,能過查看眾多網友的經驗,知道用PagedDataSource來實現。

 

Repeater分頁,需要依靠PagedDataSource。這個類存在於System.Web.UI.WebControls命名空間。它的作用是作為數據源與數據顯示控制項的中間介質。如:

  數據源->PagedDataSource->數據綁定控制項

  之間的關係通過以下代碼來實現:

  PagedDataSource pds=new PagedDataSource ();

  pds.DataSource=dataTable;

  repeater1.DataSource=pds;

  repeater1.DataBind();

這是前臺aspx頁代碼

<div id="onlinely">
<div id="xianshily">
<asp:Repeater runat="server" ID="Repeater1">
<ItemTemplate>
<ul id="xianshi1">
<li id="xianshi2">
<ul class="ly1">
<li class="ly2">留言人:</li>
<li class="ly3"><asp:Label runat="server" ID="lyren" Text='<%#Eval("lyname") %>'></asp:Label></li>
<li class="ly4">時間:</li>
</ul>
<ul class="ly1">
<li class="ly2">留言內容:</li>
<li class="ly3"><asp:Label runat="server" ID="lynr" Text='<%#Eval("neirong") %>'></asp:Label></li>
<li class="ly4"><asp:Label runat="server" ID="lyt" Text='<%#Eval("lytime") %>'></asp:Label></li>
</ul>
<ul class="ly1">
<li class="ly2">回覆:</li>
<li class="ly3"><asp:Label runat="server" ID="lyhf" Text='<%#Eval("huifu") %>'></asp:Label></li>
<li class="ly4"><asp:Label runat="server" ID="hft" Text='<%#Eval ("hftime") %>'></asp:Label></li>
</ul>
</li></ul>
</ItemTemplate>
</asp:Repeater>
</div>
<div id="pages">
<asp:hyperlink id="lnkPrev" runat="server">上頁</asp:hyperlink>
<asp:hyperlink id="lnkNext" runat="server">下頁</asp:hyperlink><asp:label id="lblCurrentPage" runat="server"></asp:label>頁
 共 <asp:label id="lblTotalPage" runat="server"></asp:label></div>
<div id="ly">
<ul>
<li>
<ul class="ly5">
<li class="ly6">姓名:</li>
<li class="ly7"><asp:TextBox runat="server" ID="lyname"></asp:TextBox></li>
</ul>
<ul class="ly5">
<li class="ly6">留言內容:</li>
<li class="ly7"><asp:TextBox runat="server" ID="lyneirong" TextMode="MultiLine" Wrap="true" Height="100px" Width="300px"></asp:TextBox></li>
</ul>


</li>
</ul>

<div id="tijiao">
<ul>
<li><asp:Button runat="server" ID="Button1" Text="提交" onclick="tijiao_Click" /></li>
<li><asp:Button runat="server" ID="quxiao" Text="取消" onclick="quxiao_Click" /></li>
</ul>
</div>
</div>
</div>

這是aspx.cs頁代碼:

using System;
using System.Data;
using System.Data.SqlClient;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;

using System.Data.Common;

public partial class onlinely : System.Web.UI.Page
{

    SqlConnection conn = new SqlConnection(System.Configuration.ConfigurationManager.ConnectionStrings["zgbygy"].ConnectionString);
   
  

    protected void Page_Load(object sender, EventArgs e)
    {
        conn.Open();
        string sql = "select * from liuyan order by lytime desc";
        SqlCommand cmd = new SqlCommand(sql, conn);
        SqlDataAdapter sda = new SqlDataAdapter(cmd);
        DataSet ds = new DataSet();
        sda.Fill(ds);
        PagedDataSource pgds=new PagedDataSource();
        pgds.DataSource = ds.Tables[0].DefaultView; 
        //        設置允許分頁
        pgds.AllowPaging = true;
        //        每頁顯示為8行
        pgds.PageSize = 8;
        //        顯示總共頁數
        lblTotalPage.Text = pgds.PageCount.ToString();
        //     當前頁
        int CurrentPage;
        //     請求頁碼為不為null設置當前頁,否則為第一頁
        if (Request.QueryString["Page"] != null)
        {

            CurrentPage = Convert.ToInt32(Request.QueryString["Page"]);
        }

        else
        {
            CurrentPage = 1;
        }
        //   當前頁所引為頁碼-1
        pgds.CurrentPageIndex = CurrentPage - 1;
        //   顯示當前頁碼
        lblCurrentPage.Text = CurrentPage.ToString();
        //   如果不是第一頁,通過參數Page設置上一頁為當前頁-1,否則不顯示連接
        if (!pgds.IsFirstPage)
        {
            //            Request.CurrentExecutionFilePath為當前請求虛擬路徑
            lnkPrev.NavigateUrl = Request.CurrentExecutionFilePath + "?Page=" + Convert.ToString(CurrentPage - 1);
        }
        //        End If
        //   如果不是最後一頁,通過參數Page設置下一頁為當前頁+1,否則不顯示連接
        if (!pgds.IsLastPage)
        {
            //    Request.CurrentExecutionFilePath為當前請求虛擬路徑
            lnkNext.NavigateUrl = Request.CurrentExecutionFilePath + "?Page=" + Convert.ToString(CurrentPage + 1);
        }


        Repeater1.DataSource =pgds;
        Repeater1.DataBind();
        cmd.Dispose();
        conn.Close();
    


  }

  protected void tijiao_Click(object sender, EventArgs e)
  {
      try
      {
          conn.Open();
          string sql = "insert into liuyan (lyname,neirong,lytime) values ('" +lyname.Text +"','" +lyneirong.Text + "','" + DateTime.Now + "')";
          SqlCommand cmd = new SqlCommand(sql, conn);
          cmd.ExecuteNonQuery();
          conn.Close();
          this.lyname.Text = "";
          this.lyneirong.Text = "";
          
          Response.Redirect("onlinely.aspx");
      }
      catch 
      {
 
      }


  }
  protected void quxiao_Click(object sender, EventArgs e)
  {

      this.lyname.Text = "";
      this.lyneirong.Text = "";

  }

  public void xinashi(object sender, EventArgs e)
  {
      conn.Open();
      string sql = "select * from liuyan";
      SqlCommand cmd = new SqlCommand(sql, conn);
      SqlDataAdapter sda = new SqlDataAdapter(cmd);
      DataSet ds = new DataSet();
      sda.Fill(ds);
      Repeater1.DataSource = ds;
      Repeater1.DataBind();
      cmd.Dispose();
      conn.Close();
 
  }
 
}

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 具體的異常信息如下,一開始沒有寫日誌只看到錯誤信息:Count must have a non-negative value.,從錶面意思可以看出來是Count值出現了負數,所以報錯,查了半天的原因也沒有看出來為什麼,直到後面,我把Linq表達式輸了出來,發現Skip(-10),我一想分頁查詢會根據 ...
  • 1、什麼是棧? 棧是一個記憶體數組,是一個後進先出的數據結構; 幾種數據類型: 1、某些類型變數的值; 2、程式當前的執行環境; 3、傳遞給方法的參數; 幾個普遍特征: 1、數據只能從棧的頂端插入和刪除; 2、把數據放到棧頂成為入棧; 3、從棧頂刪除數據成為出棧; 2、什麼是堆? 堆是一塊記憶體區域,在 ...
  • 使用asp.net創建自己的模板引擎是相當簡單的事情,而我們所使用的僅僅需要正則和反射兩個工具就足夠了。 來看看下麵一個來自於真實項目的模板頁(者進行了適當的精簡,為方便閱讀): ? <!DOCTYPE html> <html> <head> <title>${SYS_NAME}</title> < ...
  • 、CHAR。CHAR存儲定長數據很方便,CHAR欄位上的索引效率級高,比如定義char(10),那麼不論你存儲的數據是否達到了10個位元組,都要占去10個位元組的空間,不足的自動用空格填充,所以在讀取的時候可能要多次用到trim()。 2、VARCHAR。存儲變長數據,但存儲效率沒有CHAR高。如果一個 ...
  • ASP.NET MVC6已出爐多時,但現在很多項目都還在使用MVC4,所以MVC6還尚未流行開來,但是從各大新聞報紙媒體上都能或多或少的知道它的跨平臺特性,這也就彌補的ASP.NET一直以來的缺憾,所以我也開始加入研究MVC6的陣營中來,這一研究忽然發現有很多似曾相識的地方,又有很多令人拍案叫好的地 ...
  • 今天是上班第二天,今天老大安排我們做了一個簡單的WinForm登陸界面。原來連接資料庫都是用老師給的SQLHelper類來寫的,今天自己嘗試著寫一下,雖然不難但是還是遇到了些問題。 連接字元串的7種方式只嘗試了兩種,一種是本地連接,一種sa連接。 今天老大給很多關於團隊項目的經驗。比如1.記住常見的 ...
  • 程式集載入 程式集載入,CLR使用System.Reflection.Assembly.Load靜態方法,當然這個方法我們自己也可以顯式調用。 還有一個Assembly.LoadFrom方法載入指定路徑名的程式集,實際上其內部是先通過AssemblyName.GetAssemblyName獲取Ass ...
  • MVC框架之所以如此受歡迎的原因之一就是它十分註意支持關註分離,使各個功能部件儘量能夠相互獨立。今天我們就來看看MVC4如何使用DI方法實現一些組件的獨立,使本來結合緊密的部件,松耦合。我現在所說的對於.net的一些初學者來說可能有點拗口,其實我也是一個實打實的初學者,自己開始看這段話的時候遲遲不能... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...