asp.net IList查詢資料後格式化資料再繫結控制項

來源:互聯網
上載者:User

一、先講最基本的 DataSet綁定操作,GridView為例。
當操作查詢得一個 DataSet ds 後,可以進行一些資料的格式化,如: 複製代碼 代碼如下:foreach (DataRow dr in ds.Tables[0].Rows)
{
if (dr["Depth"].ToString() != "1")
{
dr["ColumnName"] = StringHelper.StringOfChar(Convert.ToInt32(dr["Depth"]) - 1, " ") + "├ " + dr["ColumnName"];
}
}
GridView1.DataSource = ds;
GridView1.DataBind();

複製代碼 代碼如下:public static class StringHelper
{
/// <summary>
/// 產生指定長度的字串,即產生strLong個str字串
/// </summary>
/// <param name="strLong">產生的長度</param>
/// <param name="str">以str產生字串</param>
/// <returns></returns>
public static string StringOfChar(int strLong, string str)
{
string ReturnStr = "";
for (int i = 0; i < strLong; i++)
{
ReturnStr += str;
}
return ReturnStr;
}
/// <summary>
/// 產生日期隨機碼
/// </summary>
/// <returns></returns>
public static string GetRamCode()
{
#region
return DateTime.Now.ToString("yyyyMMddHHmmssffff");
#endregion
}
}

像這樣很快就能進行一些資料的格式化並綁定到控制項了。
二、現在講下我主要想講的內容,如果我們用Ilist 查詢得資料後,想格式化一些字串,以達到自己想要的顯示效果,我們該怎麼辦呢?先看下再給您答案。


比如我們在做無限分類的時候 往往想讓資料如所顯示,我們又該怎麼做呢。
剛上讓面的DataSet寫了些格式化代碼,現在相信大家都想知道Ilist又該怎麼操作對吧?
泛型的功能 強大我在這裡就不說了,現在說重點,主要有兩種方法實現,
一,把Ilist得的資料轉為 DataSet的,這樣你又可以重新回到熟悉的操作了
IList 轉 DataSet 類(這個是我引用別人的 ^ ^)

複製代碼 代碼如下:public static DataSet ConvertToDataSet<T>(IList<T> list)
{
if (list == null || list.Count <= 0)
{
return null;
}
DataSet ds = new DataSet();
DataTable dt = new DataTable(typeof(T).Name);
DataColumn column;
DataRow row;
System.Reflection.PropertyInfo[] myPropertyInfo = typeof(T).GetProperties(System.Reflection.BindingFlags.Public | System.Reflection.BindingFlags.Instance);
foreach (T t in list)
{
if (t == null)
{
continue;
}
row = dt.NewRow();
for (int i = 0, j = myPropertyInfo.Length; i < j; i++)
{
System.Reflection.PropertyInfo pi = myPropertyInfo[i];
string name = pi.Name;
if (dt.Columns[name] == null)
{
column = new DataColumn(name, pi.PropertyType);
dt.Columns.Add(column);
}
row[name] = pi.GetValue(t, null);
}
dt.Rows.Add(row);
}
ds.Tables.Add(dt);
return ds;
}

然後 複製代碼 代碼如下:DataSet ds = ConvertToDataSet(b.ListColumn());

看,又回來熟悉的操作了吧,但是,這樣做我們啟不是走彎路了,為啥不直接用 DataSet就得了?沒錯,我們走彎路了............我想用 IList啊,不想轉來轉去的,難道就沒有好的辦法?
哈哈,答案肯定是有的,也是最簡單的,往往是初學的朋友不懂解IList才現在種種疑惑,
現在講IList 對象類的操作
還是上面的例子
比如當查詢得一個 複製代碼 代碼如下:BLL b = new BLL();
b.ListColumn();

我們要綁定所示的只需這樣做

複製代碼 代碼如下:IList<Qzzm.Model.ColumnInfo> list = new List<Qzzm.Model.ColumnInfo>();
foreach (Qzzm.Model.ColumnInfo m in b.ListColumn())
{
if (m.Depth.ToString() != "1")
{
m.ColumnName = StringHelper.StringOfChar(Convert.ToInt32(m.Depth) - 1, " ") + "├ " + m.ColumnName + "<br>";
}
list.Add(m);
}
DataList1.DataSource = list;
DataList1.DataBind();

StringHelper還是上面的那個。經過這樣的簡單處理,我們就可以格式化 欄目名稱了再分下DataList的綁定,完畢!算是菜鳥與菜鳥之間的交流吧。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.