程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> C# >> 關於C# >> 如何使用DataGrid動態綁定DropDownList

如何使用DataGrid動態綁定DropDownList

編輯:關於C#
 

簡單的使用模板列綁定DropDownList,初學者想必都會了,但有時候,我們要做的就是在編輯的時候想讓某一列定制為DropDownList,並且根據正常情況下顯示的值自動變換DropDownList中所選的值,然後保存選擇後的值到數據庫或XML文件,其實要做到這樣的功能並不難,只要我們學會使用DataGrid的DataGrid1_ItemDataBound事件就行了,跟我來做個例子。
//檢索數據庫的函數
public DataSet GetZcbd()
{
try
{
DataSet ds=new DataSet();
string searchString="select id,yy,bj from zc";
da=new OleDbDataAdapter(searchString,conn);
da.Fill(ds,"yy");
return ds;
}
catch
{
return null;
}
}


//綁定DataGrid
private void BindGrid()
{
DataSet ds = new DataSet();
ds = us.GetZcbd();
if (ds!=null)
{
this.DataGrid1.DataSource = ds;
this.DataGrid1.DataBind();
}
else
{
msg.Alert("加載數據錯誤!",Page);
}
}

綁定好DataGrid以後,設定模板列,讓其正常顯示下為Label,並綁定為數據庫中一ID值,在編輯狀態下為DropDownList,並綁定為數據庫中一Name值,我們現在要做的就是當我們選擇編輯時根據Label的值自動從數據庫中取出編號為ID值的姓名,並用DropDownList默認選中。(注釋:為了方便大家學習,我給出一個簡單代碼的例子,供大家參考)

private void DataGrid1_ItemDataBound(object sender, System.Web.UI.WebControls.DataGridItemEventArgs e)
{
if (e.Item.ItemType == ListItemType.EditItem)
{
DataRowView drv = (DataRowView)e.Item.DataItem;
string current = drv["label1"].ToString();
DropDownList ddl = (DropDownList)e.Item.FindControl("ddl");
ddl.SelectedIndex = ddl.Items.IndexOf(ddl.Items.FindByValue(current));
}
if ((e.Item.ItemType == ListItemType.Item)||(e.Item.ItemType == ListItemType.AlternatingItem))
{
Label t = (System.Web.UI.WebControls.Label)e.Item.FindControl("label1");
string current = this.BindDDL(int.Parse(t.Text));
e.Item.Cells[1].Text = current;
}
}

private string BindDDL(int ddd)
{
string sss = "";
if (ddd==1)
{
sss="張三";
return sss;
}
else
{
sss="李四";
return sss;
}
}

 


注釋:msg為一個類似WinForm的messagebox對話框,不必理會。可以使用label.Text代替
 

 
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved