ASP.NET 頁面中動態(tài)增加的控件、添加事件
更新時間:2009年07月16日 01:10:47 作者:
在ASP.NET中動態(tài)創(chuàng)建一個控件總是不那么順利,特別是當(dāng)對頁面的Life Cycle不是那么了然的情況下!這里簡單描述一下要求,然后提供一個解決方案,大家看看有沒有更好的Idea,如果有的話就是我的大幸了,呵呵!
asp.net 中服務(wù)器端控件動態(tài)添加事件和刪除事------------------------------------------
PlaceHolder :控件容器,本身不顯示,主要用來放服務(wù)器控件的,只顯示其子元素(他里面的控件)
服務(wù)器控件動態(tài)添加和刪除
<一>PlaceHolder 中動態(tài)添加服務(wù)器端控件
添加控件的一般方法:
聲明一個新控件 如 label lb =new label()
設(shè)置控件屬性 如:lb.text="text"
添加控件到 PlaceHolder 中 如: PlaceHolder1.controls.add(lb)
可以用 ViewState[AddedControl]=null 判斷是不是第一次執(zhí)行
動態(tài)添加控件,如果需要數(shù)據(jù)綁定,要先添加控件,然后再數(shù)據(jù)綁定,提交后(postback) 就不需要重新綁定了
new 一下就可以了,如:
復(fù)制代碼 代碼如下:
if ((ViewState[AddedControl] != null) & ((bool)ViewState[AddedControl]))//第二次就不要數(shù)據(jù)綁定了
{
ph1.Controls.Clear();//清除ph1中的控件
DropDownList dpl = new DropDownList();
dpl.ID = "controlid";
dpl.AutoPostBack = true;
ph1.Controls.Add(dpl);
}
else
{
ph1.Controls.Clear();
DropDownList dpl = new DropDownList();
dpl.ID = "controlid";
dpl.AutoPostBack = true;
ph1.Controls.Add(dpl);
//鏈接數(shù)據(jù)庫,設(shè)置數(shù)據(jù)源等 略
dpl.DataBind();
ViewState[AddedControl] = true;
}
<二>panel中動態(tài)添加服務(wù)器端控件
在一個panel 中添加datagrid 并且綁定數(shù)據(jù)
復(fù)制代碼 代碼如下:
Panel panel1 = new Panel();
panel1.Style["top"] = "200px";//設(shè)置屬性
this.Controls.Add(panel1);
DataGrid dg1 = new DataGrid();//定義datagrid
BoundColumn s1 = new BoundColumn();//定義一列
s1.DataField = "first";//綁定列的數(shù)據(jù)源
s1.HeaderText = "mzi";//此列標(biāo)題等屬性設(shè)置
dg1.Columns.Add(s1);//加入此列
dg1.BackColor = "#00000";
dg1.CellPadding=3;
//設(shè)置 dg1的屬性等
panel1.Controls.Add(dg1);
<三> 給動態(tài)添加的控件添加事件:
如:給button 添加事件
復(fù)制代碼 代碼如下:
//添加按鈕1
Button bt1 = new Button();
bt1.CommandArgument = "bt1";//設(shè)置命令參數(shù)
bt1.Text = "daji";
bt1.Command += new CommandEventHandler(this.onbutton);//預(yù)定事件
ph1.Controls.Add(bt1);
//添加按鈕2,又一種方法
Control cs = ParseControl("<asp:Button ID='Button2' runat='server' Text=Button' commandname='btn' CommandArgument = 'bt2'/>");//把字符串轉(zhuǎn)化為控件
ph1.Controls.Add(cs);
Button bt2 = (Button)Page.FindControl("button2");
bt2.Command += new CommandEventHandler(this.onbutton);//給bt2添加事件
}
public void onbutton(object sender, CommandEventArgs e)
{
lab1.text = "label1";
}
這樣二個按鈕都對應(yīng)一個函數(shù),執(zhí)行同一個事件
如果想讓他們執(zhí)行不同事件,
可以這樣寫:
復(fù)制代碼 代碼如下:
public void onbutton(object sender, CommandEventArgs e)
{
switch (e.CommandArgument.ToString().ToLower()) 獲取命令參數(shù),根據(jù)參數(shù)的不同,執(zhí)行不同命令
{
case "bt1":lab1.text = "label1"; break;
case "bt2":lab1.text = "label2"; break;
}
}
<四>:在table中添加行和服務(wù)器端控件
在table中添加一行二列 table要轉(zhuǎn)化服務(wù)器端控件
代碼如下:
復(fù)制代碼 代碼如下:
HtmlTableRow tr1 = new HtmlTableRow();//定義行
HtmlTableCell td1 = new HtmlTableCell();//定義列
Label lb1 = new Label();// 定義 lb1 為Label控件
lb1.Text = txt[m];//lb1
td1.Controls.Add(lb1);//列中添加lbl
HtmlTableCell td2 = new HtmlTableCell();//定義列
TextBox txt1 = new TextBox();//textbox
txt1.Text = namevalue[m];//text
txt1.ID = "t" + m;//id
td2.Controls.Add(txt1);列中添加txt1
tr1.Cells.Add(td1);//行中添加列td1
tr1.Cells.Add(td2);//行中添加列td1
TABLE1.Rows.Add(tr1);//表中添加行
取得textbox中數(shù)據(jù)方法:
((TextBox)(TABLE1.Rows[m].FindControl("t" + m))).Text 第m行 id 為"t"+m的控件的值
添加html 控件,可以用 response.write("")
為服務(wù)器端控件添加客戶端事件方法;
如:buttton.Attributes["onclick"] = "javascript:alert('shijain')";
您可能感興趣的文章:
- asp.net GridView控件中模板列CheckBox全選、反選、取消
- asp.net 打印控件使用方法
- asp.net+jquery滾動滾動條加載數(shù)據(jù)的下拉控件
- Asp.net 菜單控件簡潔版
- asp.net AjaxControlToolKit--TabContainer控件的介紹
- ASP.NET單選按鈕控件RadioButton常用屬性和方法介紹
- Asp.Net數(shù)據(jù)控件引用AspNetPager.dll分頁實現(xiàn)代碼
- ASP.NET 2.0/3.5中直接操作Gridview控件插入新記錄
- asp.net fileupload控件上傳文件與多文件上傳
- asp.net基礎(chǔ)學(xué)習(xí)之控件的使用方法
相關(guān)文章
ASP.NET?Core使用EF?SQLite對數(shù)據(jù)庫增刪改查
這篇文章介紹了ASP.NET?Core使用EF?SQLite對數(shù)據(jù)庫增刪改查的方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-01-01ASP.NET動態(tài)設(shè)置頁面標(biāo)題的方法詳解
這篇文章介紹了ASP.NET動態(tài)設(shè)置頁面標(biāo)題的方法詳解,有需要的朋友可以參考一下2013-07-07.net?core利用PdfSharpCore操作PDF實例教程
操作pdf是我們?nèi)粘i_發(fā)中經(jīng)常遇到的功能,下面這篇文章主要給大家介紹了關(guān)于.net?core利用PdfSharpCore操作PDF實例的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-12-12Asp.net 2.0 無刷新圖片上傳 顯示縮略圖 具體實現(xiàn)
簡單三步實現(xiàn)圖片無刷新上傳:注意是上傳,至于上傳時的驗證,比如圖片的尺寸,大小,格式。自行解決。如果我搞定了,也會貼上來的。2013-06-06NET Core TagHelper實現(xiàn)分頁標(biāo)簽
這篇文章主要介紹了NET Core TagHelper實現(xiàn)分頁標(biāo)簽,講述實現(xiàn)一個簡單分頁和總要注意步奏,感興趣的小伙伴們可以參考一下2016-07-07