XP 风格的可拖动列、可排序、可改变宽度的DataGrid的例子
生活随笔
收集整理的這篇文章主要介紹了
XP 风格的可拖动列、可排序、可改变宽度的DataGrid的例子
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
利用客戶端腳本的優勢,我們可以創建出可以拖動列,改變列寬度,顯示、隱藏列的XP風格的 DataGrid,下面就是所有的代碼。自己調試時請注意修改eMeng.Exam.UltraGrid路徑。
查看例子
UltraGrid.aspx
XP 風格的可拖動列、可排序、可改變寬度的DataGrid的例子 ?XP 風格的可拖動列、可排序、可改變寬度的DataGrid的例子。UltraGrid.aspx.cs
using System; using System.Collections; using System.ComponentModel; using System.Data; using System.Data.OleDb; using System.Drawing; using System.Web; using System.Web.SessionState; using System.Web.UI; using System.Web.UI.WebControls; using System.Web.UI.HtmlControls; namespace eMeng.Exam.UltraGrid { /// /// UltraGrid 的摘要說明。本例子演示了如何創建可排序、可拖放、可調整寬度的XP風格的DataGrid。 /// 出自:【孟憲會之精彩世界】 /// public class UltraGrid : System.Web.UI.Page { protected System.Web.UI.HtmlControls.HtmlGenericControl gridRow; protected System.Web.UI.WebControls.Literal RowItem; protected System.Web.UI.HtmlControls.HtmlGenericControl coolUltraGrid1; private void Page_Load(object sender, System.EventArgs e) { // 在此處放置用戶代碼以初始化頁面 coolUltraGrid1.Attributes.Add("class","coolUltraGrid"); coolUltraGrid1.Attributes.Add("style","WIDTH: 100%; HEIGHT: 400"); coolUltraGrid1.Attributes.Add("borderStyle","2"); coolUltraGrid1.Attributes.Add("altRowColor","oldLace"); coolUltraGrid1.Attributes.Add("selectionStyle","1"); /// 請根據你的數據庫的設置,修改這里的數據庫連接字符串和查詢語句。其它不要修改。 OleDbConnection cn = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=c:\\xxx.mdb"); cn.Open(); string sqlstring = "SELECT TOP 30 D.Title As 文檔標題,D.CreateDate as 發布時間,S.Title AS 所屬欄目 "; sqlstring += "FROM Document D,Subject S WHERE D.pid=S.id ORDER BY D.CreateDate DESC"; OleDbCommand cmd = new OleDbCommand(sqlstring,cn); OleDbDataReader dr; dr=cmd.ExecuteReader(CommandBehavior.CloseConnection); /// ///組合表頭 /// int FieldNumber = dr.FieldCount; int ColWidth,Tmp = 0; if(FieldNumber == 0) Response.End(); ColWidth = (int)100/FieldNumber; string TableHeader = ""; for(int i=0;i"+dr.GetName(i).ToString()+""; else TableHeader +=""+dr.GetName(i).ToString()+""; Tmp+=ColWidth; } } gridRow.InnerHtml=TableHeader; int RowNumber = 1; TableHeader = " "; while(dr.Read()) { TableHeader += " "; for(int i=0;i"+dr.GetValue(i).ToString()+""; } TableHeader += " "; RowNumber++; } TableHeader += " "; RowItem.Text=TableHeader; cn.Close(); } #region Web Form Designer generated code override protected void OnInit(EventArgs e) { // // CODEGEN:該調用是 ASP.NET Web 窗體設計器所必需的。 // InitializeComponent(); base.OnInit(e); } /// /// 設計器支持所需的方法 - 不要使用代碼編輯器修改 /// 此方法的內容。 /// private void InitializeComponent() { this.Load += new System.EventHandler(this.Page_Load); } #endregion } }轉載于:https://www.cnblogs.com/xuxianpeng/archive/2006/10/31/545587.html
總結
以上是生活随笔為你收集整理的XP 风格的可拖动列、可排序、可改变宽度的DataGrid的例子的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 深入Atlas系列:客户端网络访问基础结
- 下一篇: 基于窗体的身份验证