天天看点

关于动态生成DropDownList遇到的问题

关于动态生成DropDownList遇到的问题

我是个新手,今天研究DDL控件的动态生成的时候遇到了点问题 ,当我写代码的时候发现点击button后 只能创建一个DDL控件,再点击就没有作用了,后来我在里面设置了变量,看看这个事件是不是没有执行,发现变量并没有改变,刚刚有点疑惑不解,后来发现当我触发其它事件的时候,控件消失了!我想,button的click事件会回传,而回传后新建的控件就会消失,我才明白,原来每次都有创建新的控件,只是每次再次点击button的时候回传页面,导致之前产生的控件消失了,而那唯一的一个控件是这次生成的,我又查询了一下asp的生命周期 看来对于页面的生命周期理解的不清楚会出好多问题。

简单的说 页面的生命周期分为下面几个过程

1.初始化(Init)

2.控件状态的装载(LoadControlState)

3.视图装载(LoadViewState)

4.回传的数据处理(LoadPostData)

5.页面加载(OnLoad)

6.渲染(OnPreRender)

7.保存视图状态(SaveViewState)

8.保存控件状态(SaveControlState)

9.呈现(Render)

这里当我在新点击button触发新建DDL控件的事件的时候,这个事件执行了,但是上一次创建的控件并没有保存状态,所以出现了上面的问题

简单研究了一下保存状态的方法,就是把状态保存到HiddenField中

<body>
    <form id="form1" runat="server">
    <div>
        <asp:HiddenField ID="hidden" runat="server" />
        <asp:Button ID="Btn" runat="server" Text="动态创建" 
            onclick="Btn_Click" />
        <asp:Button ID="GetValue" runat="server" Text="获取选中的值" 
            onclick="GetValue_Click" />
        <asp:Label ID="lbl" runat="server" Text=""></asp:Label>
        <asp:Panel ID="PanelControl" runat="server">
        </asp:Panel>
    </div>
    </form>
</body>
      

下面是动态创建code  原理为点击按钮 给HiddenField赋值或者可以给ViewState赋值然后再创建控件,这样再每次进入页面的时候,判断iddenField或者Viewstate是否有值,有就显示那个动态创建的控件,这样就把状态保存住了,当你再点击其他控件时,既不会再消失了。

protected void Page_Load(object sender, EventArgs e)      
if (!string.IsNullOrEmpty(Hidden.Value) && Hidden.Value=="flag")
        {
            CreateDropDownList();
        }
if(!isPostBack)  //创建控件不能写在这里,这个是判断是否为回发  
{
}
}
       
protected void Btn_Click(object sender, EventArgs e)//创建控件
    {
        Hidden.Value = "flag";//这里说明已经创建过一个控件了
        CreateDropDownList();
    }
接下来是创建ddl的基本代码
       
private void CreateDropDownList()
    {
        DropDownList ddl = new DropDownList();
        ddl.ID = "ddl";
        ddl.Items.Add(new ListItem("1", "1"));
        ddl.AutoPostBack = true;
        ddl.SelectedIndexChanged += new EventHandler(ddl_SelectedIndexChanged);//给ddl添加事件
        PanelControl.Controls.Add(ddl); //放进容器
    } 
下面为点击控件  获得动态创建的控件选中的值  道理也是回发
       
protected void GetValue_Click(object sender, EventArgs e)
    {
        DropDownList ddl = PanelControl.FindControl("ddl") as DropDownList;
        if (ddl != null)
        {
            lbl.Text ="点击按钮得到的值为"+ddl.SelectedValue;
        }
    }
动态创建的ddl的事件,
       
protected void ddl_SelectedIndexChanged(object sender, EventArgs e)
    {
        DropDownList ddl= sender as DropDownList;
        if (ddl != null)
        {
            lbl.Text ="通过自身回发事件得到的值为"+ddl.SelectedValue;
        }
    }