简体   繁体   English

如何在 asp.net/webforms c# 中以动态方式创建运行时控件?

[英]How to dinamycally create runtime controls in asp.net/webforms c#?

I've a table in a database with this structure:我在具有这种结构的数据库中有一个表:

  • field_order字段顺序

  • field_label字段标签

  • field_name字段名称

  • field_type字段类型

  • width宽度

  • heigth高度

I want to loop through all rows and create controls in my page, putting them in classic table 2 columns x X rows (each row a control).我想遍历所有行并在我的页面中创建控件,将它们放在经典表中 2 列 x X 行(每行一个控件)。

This is server side code:这是服务器端代码:

 using (MySqlConnection db = new MySqlConnection(myAppConnectionString))
            {
                string sql = "SELECT * FROM myTable WHERE idtemplate =" + templateID.ToString() + " ORDER BY field_order";
                MySqlDataReader dr;
                MySqlCommand cmd = new MySqlCommand(sql,db);

                db.Open();

                dr = cmd.ExecuteReader();
                if (dr.HasRows)
                {
                    while (dr.Read())
                    {
                        string field_label = dr["field_label"].ToString();
                        string field_name  = dr["field_name"].ToString();
                        string field_type = dr["field_type"].ToString();
                        string field_width = dr["width"].ToString();
                        string field_height = dr["height"].ToString();

                        switch (field_type)
                        {
                            case "Text":
                                Label lbl = new Label();
                                lbl.Text = field_label;
                                lbl.ID = "lbl" + field_name;
                                panelFields.Controls.Add(lbl);

                                TextBox txt = new TextBox();
                                txt.Text = "";
                                txt.ID = "txt" + field_name;
                                Unit ut = new Unit(field_width);
                                txt.Width = ut;
                                ut = new Unit(field_height);
                                txt.Height = ut;
                                panelFields.Controls.Add(txt);


                                break;
                            case "Number":
                                break;
                            case "Date":
                                break;
                            case "Time":
                                break;
                        }
                    }
                }

            }

Using panelFields.Controls.Add(myControl) I add each controls in a panel but next to each other.使用panelFields.Controls.Add(myControl)我将每个控件添加到面板中但彼此相邻。

So my questions are:所以我的问题是:

1- How can I add controls in a table 2 columns x N rows ? 1- 如何在 2 列 x N 行的表格中添加控件?

2- If I add controls in this way, Will it possible for me to access from server side to save TextBox values ? 2- 如果我以这种方式添加控件,我是否可以从服务器端访问以保存 TextBox 值?

Thanks谢谢

I solved adding "Literal" controls to myPanel with HTML Tag.我解决了使用 HTML 标签向 myPanel 添加“文字”控件的问题。

Like:喜欢:

myPanel.Controls.Add(new LiteralControl("")); myPanel.Controls.Add(new LiteralControl(""));

myPanel.Controls.Add(new LiteralControl(" ")); myPanel.Controls.Add(new LiteralControl(" "));

.... ....

myPanel.Controls.Add(new LiteralControl("")); myPanel.Controls.Add(new LiteralControl(""));

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM