動態加入 ASP.NET 控制項 與 事件 (YouTube教學影片)

https://dotblogs.com.tw/mis2000lab/2016/07/25/dynamic_add_controls_event

 

 

 

Q :  動態加入三個 CheckBox(已設定 AutoPostBack)

      被點選後,觸發事件

 

Youtube教學影片 -- https://youtu.be/GtI8P0Onods

HTML畫面是空白,因為這三個CheckBox控制項,是寫程式加入的。  

Controls.Add() 動態加入控制項

後置程式碼:

    protected void Page_Init(object sender, EventArgs e)
    {
        CheckBox CB = new CheckBox();
        CB.ID = "CheckBox1";
        CB.AutoPostBack = true;
        CB.Text = "第一層";
        CB.CheckedChanged += new System.EventHandler(this.myCB_CheckedChanged);  // 動態加入事件,後面是「事件名稱」
        Page.Form.Controls.Add(CB);

        CheckBox CB2 = new CheckBox();
        CB2.ID = "CheckBox2";
        CB2.AutoPostBack = true;
        CB2.Text = "第二層";
        CB2.CheckedChanged += new System.EventHandler(this.myCB_CheckedChanged);  // 動態加入事件,後面是「事件名稱」
        Page.Form.Controls.Add(CB2);

        CheckBox CB3 = new CheckBox();
        CB3.ID = "CheckBox3";
        CB3.AutoPostBack = true;
        CB3.Text = "第三層";
        CB3.CheckedChanged += new System.EventHandler(this.myCB_CheckedChanged);  // 動態加入事件,後面是「事件名稱」
        Page.Form.Controls.Add(CB3);
    }

    protected void Page_Load(object sender, EventArgs e)
    {

    }

    protected void myCB_CheckedChanged(object sender, EventArgs e)
    {
        CheckBox CB = (CheckBox)sender;

        if(CB.Checked){
            Response.Write("<h3>" + CB.ID + "......被點選了!!</h3>");
        }
        else {
            Response.Write("<h3>**" + CB.ID + "......「沒有」被點選**</h3>");
        }        
    }

 

動態加入事件,可以參閱

ASP.NET 動態加入 事件處理常式--AddHandler , AddressOf , EventHandler , Handler
https://dotblogs.com.tw/mis2000lab/2011/11/05/eventhandler_addhandler_addressof_method

 

Page_Init事件裡面的程式  請您自己調整一下,

這裡程式碼很累贅,您自己抽離出來,收斂成一個副程式吧

 

事件裡面的 sender也是滿有趣的,如果您不會的話,來上課吧

這是第一天下午就會提到的基本觀念喔  (課程請看 文章底下的說明)

    [遠距教學、教學影片] ASP.NET (Web Form) 課程 上線了!微軟MVP --MIS2000Lab.主講

    事先錄製好的影片,並非上課時側錄!   觀看影片時,有如我「一對一」跟您面對面講課

    

 

 

 

 

 

 

arrow
arrow
    全站熱搜

    MIS2000 Lab 發表在 痞客邦 留言(0) 人氣()