[英]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.