/--------------------------利用计数器实现动态button的累加---------------------------------/
在ASP.NET中动态创建一个控件总是不那么顺利,特别是当对页面的Life Cycle不是那么了然的情况下!这里简单描述一下要求,然后提供一个解决方案,大家看看有没有更好的Idea,如果有的话就是我的大幸了,呵呵!
要求:页面上有一个Add按钮,每点击一次该按钮,页面上动态创建一个WebPartZone!
提醒:WebPartZone只能在OnInit或之前才能创建,否则报异常!
大家都知道,按钮的点击事件是在RaisePostbackEvent时触发的,这意味着点击事件在OnLoad阶段之后才执行,远远落后于 OnInit阶段,而且ViewState在OnLoad时才准备好,OnInit以及之前的阶段根本就不能使用ViewState!如果试图在按钮点击 事件里面创建WebPartZone等控件,唯一的后果就是页面出错;而如果在OnInit里面创建控件,由于ViewState没有准备好,那么有些数 据比如当前需要创建的个数(存在ViewState里面)就无法获得!
目前对这个问题我还没有找到什么好的解决方案,经过实验,勉强得出一个不怎么优雅的方案,就是利用HiddenField保存数据,然后直接使 用Request.Form["XXX"]在OnInit阶段取得数据;而判断是否点击按钮也是通过Request.Form是否存在对应数据来判断的! 废话不多说了,大家看看代码吧!
==========================动态添加事件===================================
实现的功能是在网页上的Panel中动态添加一个Button,并为这个Button写一个单击事件。
动态添加控件的事件,语句:
- Control.Command += new CommandEventHandler(this.EventFun);
具体的代码请看下面:
需要特别注意的是:
添加控件和给控件加事件时绝对不能放到 if(!IsPostback){}里面,那样的话,点击一次后控件会消失,而且事件也不
会执行。
- protected void Page_Load(object sender, EventArgs e)
- {
-
- Control c = ParseControl("<asp:Button Text =& nbsp;'按我' ID = 'myButton' commandargument =& nbsp;'b' runat = 'server' />");
-
-
- this.Panel1.Controls.Add(c);
-
-
- Button Button = (Button)Page.FindControl("myButton");
-
-
- Button.Command += new CommandEventHandler(this.On_Button);
-
- }
-
-
- protected void On_Button(Object sender,CommandEventArgs e)
- {
- Response.Write("<mce:script language = 'javascript' type = 'text/javascript'><!--
- alert('" + e.CommandArgument.ToString() + "');
-
- }
-----------------------------------------asp.net为控件动态添加事件----------------------------------------------------
实现的功能是在网页上的Panel中动态添加一个Button,并为这个Button写一个单击事件。
动态添加控件的事件,语句:
- Control.Command += new CommandEventHandler(this.EventFun);
具体的代码请看下面:
需要特别注意的是:
添加控件和给控件加事件时绝对不能放到 if(!IsPostback){}里面,那样的话,点击一次后控件会消失,而且事件也不
会执行。
- protected void Page_Load(object sender, EventArgs e)
- {
-
- Control c = ParseControl("<asp:Button Text =& nbsp;'按我' ID = 'myButton' commandargument =& nbsp;'b' runat = 'server' />");
-
-
- this.Panel1.Controls.Add(c);
-
-
- Button Button = (Button)Page.FindControl("myButton");
-
-
- Button.Command += new CommandEventHandler(this.On_Button);
-
- }
-
-
- protected void On_Button(Object sender,CommandEventArgs e)
- {
- Response.Write("<mce:script language = 'javascript' type = 'text/javascript'><!--
- alert('" + e.CommandArgument.ToString() + "');
-
- }
-----------------------------asp.net 中服务器端控件动态添加事件和删除事------------------------------------------
PlaceHolder :控件容器,本身不显示,主要用来放服务器控件的,只显示其子元素(他里面的控件)
服务器控件动态添加和删除
<一>PlaceHolder 中动态添加服务器端控件
添加控件的一般方法:
声明一个新控件 如 label lb =new label()
设置控件属性 如:lb.text="text"
添加控件到 PlaceHolder 中 如: PlaceHolder1.controls.add(lb)
可以用 ViewState[AddedControl]=null 判断是不是第一次执行
动态添加控件,如果需要数据绑定,要先添加控件,然后再数据绑定,提交后(postback) 就不需要重新绑定了
new 一下就可以了,如:
- if ((ViewState[AddedControl] != null) & ((bool)ViewState[AddedControl]))
- {
- ph1.Controls.Clear();
- 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);
-
- dpl.DataBind();
- ViewState[AddedControl] = true;
- }
<二>panel中动态添加服务器端控件
在一个panel 中添加datagrid 并且绑定数据
- Panel panel1 = new Panel();
- panel1.Style["top"] = "200px";
- this.Controls.Add(panel1);
- DataGrid dg1 = new DataGrid();
- BoundColumn s1 = new BoundColumn();
- s1.DataField = "first";
- s1.HeaderText = "mzi";
- dg1.Columns.Add(s1);
- dg1.BackColor = "#00000";
- dg1.CellPadding=3;
-
- panel1.Controls.Add(dg1);
<三> 给动态添加的控件添加事件:
如:给button 添加事件
-
- Button bt1 = new Button();
- bt1.CommandArgument = "bt1";
- bt1.Text = "daji";
- bt1.Command += new CommandEventHandler(this.onbutton);
- ph1.Controls.Add(bt1);
-
- Control cs = ParseControl("<asp:Button ID='Button2' runat='server' Text=Button' commandname='btn' CommandArgument = 'bt2'/>");
- ph1.Controls.Add(cs);
- Button bt2 = (Button)Page.FindControl("button2");
- bt2.Command += new CommandEventHandler(this.onbutton);
- }
- public void onbutton(object sender, CommandEventArgs e)
- {
- lab1.text = "label1";
- }
这样二个按钮都对应一个函数,执行同一个事件
如果想让他们执行不同事件,
可以这样写:
- public void onbutton(object sender, CommandEventArgs e)
- {
- switch (e.CommandArgument.ToString().ToLower()) 获取命令参数,根据参数的不同,执行不同命令
- {
- case "bt1":lab1.text = "label1"; break;
- case "bt2":lab1.text = "label2"; break;
- }
- }
<四>:在table中添加行和服务器端控件
在table中添加一行二列 table要转化服务器端控件
代码如下:
- HtmlTableRow tr1 = new HtmlTableRow();
- HtmlTableCell td1 = new HtmlTableCell();
- Label lb1 = new Label();
- lb1.Text = txt[m];
- td1.Controls.Add(lb1);
- HtmlTableCell td2 = new HtmlTableCell();
- TextBox txt1 = new TextBox();
- txt1.Text = namevalue[m];
- txt1.ID = "t" + m;
- td2.Controls.Add(txt1);列中添加txt1
- tr1.Cells.Add(td1);
- tr1.Cells.Add(td2);
- TABLE1.Rows.Add(tr1);
取得textbox中数据方法:
((TextBox)(TABLE1.Rows[m].FindControl("t" + m))).Text 第m行 id 为"t"+m的控件的值
添加html 控件,可以用 response.write("")
为服务器端控件添加客户端事件方法;
如:buttton.Attributes["onclick"] = "javascript:alert('shijain')";