
C#WEB 用DataTable绑定DropDownList的问题
我是c#初学者我想把一段字符串填充到DataTable里面,然后绑定到DropDownList里,请问要怎么做,以下是我的代码。publicstaticDataTable...
我是c#初学者
我想把一段字符串填充到DataTable里面,然后绑定到DropDownList里,
请问要怎么做,以下是我的代码。
public static DataTable Getdt()
{
string str = "a,b,c,d,e,f,g";
DataTable dt=new DataTable();
string[] stray=str.Split(',');
for (int i = 0; i < stray.Length; i++)
{
dt.Columns.Add(stray[i].ToString());
}
return dt;
}
=============================
ddl1.DataSource = bll.Getdt();
ddl1.DataTextField = "a";
ddl1.DataValueField = "b";
ddl1.DataBind();
因为初学,所以反复的试,还是没结果。 展开
我想把一段字符串填充到DataTable里面,然后绑定到DropDownList里,
请问要怎么做,以下是我的代码。
public static DataTable Getdt()
{
string str = "a,b,c,d,e,f,g";
DataTable dt=new DataTable();
string[] stray=str.Split(',');
for (int i = 0; i < stray.Length; i++)
{
dt.Columns.Add(stray[i].ToString());
}
return dt;
}
=============================
ddl1.DataSource = bll.Getdt();
ddl1.DataTextField = "a";
ddl1.DataValueField = "b";
ddl1.DataBind();
因为初学,所以反复的试,还是没结果。 展开
4个回答
展开全部
DataTable就相当于表格,它的列是自定义的,你在这个只定义了列,而没有添加行,行其实是表格的数据,每一行的数据个数是由你的列的个数组成,且为自动编号.如下所示:
a b c d e f g
1 v11 v12 v13 v14 v15 v16 v17
2 v21 v22 v23 v24 v25 v26 v27
这里你只添加了列a,b,c,d,e,f,g.而 DropDownList绑定的是表里面的数据,
所以你应该在绑定前添加数据.如下所示
dt.Rows.Add("v11","v12","v13","v14","v15","v16","v17");
dt.Rows.Add("v21","v22","v23","v24","v25","v26","v27");
a b c d e f g
1 v11 v12 v13 v14 v15 v16 v17
2 v21 v22 v23 v24 v25 v26 v27
这里你只添加了列a,b,c,d,e,f,g.而 DropDownList绑定的是表里面的数据,
所以你应该在绑定前添加数据.如下所示
dt.Rows.Add("v11","v12","v13","v14","v15","v16","v17");
dt.Rows.Add("v21","v22","v23","v24","v25","v26","v27");
展开全部
你只写了Columns没NewRow啊
public static DataTable Getdt()
{
string str = "a,b,c,d,e,f,g";
DataTable dt=new DataTable();
string[] stray=str.Split(',');
dt.Columns.Add("col")
for (int i = 0; i < stray.Length; i++)
{
DataRow dr = dt.Columns.NewRow();
dr["col"] = stray[i].ToString();
dt.Rows.add(dr);
}
return dt;
}
=============================
ddl1.DataSource = bll.Getdt();
ddl1.DataTextField = "col";
ddl1.DataValueField = "col";
ddl1.DataBind();
public static DataTable Getdt()
{
string str = "a,b,c,d,e,f,g";
DataTable dt=new DataTable();
string[] stray=str.Split(',');
dt.Columns.Add("col")
for (int i = 0; i < stray.Length; i++)
{
DataRow dr = dt.Columns.NewRow();
dr["col"] = stray[i].ToString();
dt.Rows.add(dr);
}
return dt;
}
=============================
ddl1.DataSource = bll.Getdt();
ddl1.DataTextField = "col";
ddl1.DataValueField = "col";
ddl1.DataBind();
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
public static DataTable Getdt()
{
string str = "a,b,c,d,e,f,g";
DataTable dt=new DataTable();
dt.Columns.Add("a");
dt.Columns.Add("b");
string[] stray=str.Split(',');
for (int i = 0; i < stray.Length; i++)
{
dt.Rows.Add(stray[i],stray[i]);
}
return dt;
}
=============================
ddl1.DataSource = bll.Getdt();
ddl1.DataTextField = "a";
ddl1.DataValueField = "b";
ddl1.DataBind();
我没有调试,你自己试试看, 注意调试,DataTable就是一个表格,你给他创建两列,然后逐行的添加数据。
DropDownList需要绑定两个字段的数据源,一个用来显示的DataTextField ,
一个用来存储的DataValueField ,绑定的时候"="后面实际上就是DataTable里面的数据列的名字。
{
string str = "a,b,c,d,e,f,g";
DataTable dt=new DataTable();
dt.Columns.Add("a");
dt.Columns.Add("b");
string[] stray=str.Split(',');
for (int i = 0; i < stray.Length; i++)
{
dt.Rows.Add(stray[i],stray[i]);
}
return dt;
}
=============================
ddl1.DataSource = bll.Getdt();
ddl1.DataTextField = "a";
ddl1.DataValueField = "b";
ddl1.DataBind();
我没有调试,你自己试试看, 注意调试,DataTable就是一个表格,你给他创建两列,然后逐行的添加数据。
DropDownList需要绑定两个字段的数据源,一个用来显示的DataTextField ,
一个用来存储的DataValueField ,绑定的时候"="后面实际上就是DataTable里面的数据列的名字。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
dt.Columns.Add(stray[i].ToString());
定义的事表的title,列
需要添加数据“行”
定义的事表的title,列
需要添加数据“行”
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询