在GridView的里编辑状态下,怎么绑定其中的下拉列表? 30
protectedvoidGridView1_RowDataBound(objectsender,GridViewRowEventArgse){if(((DropDown...
protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e){
if (((DropDownList)e.Row.FindControl("DDLsProject")) != null)
{
DropDownList ddlsProject = (DropDownList)e.Row.FindControl("DDLsProject");
// 生成 DropDownList 的值,绑定数据
string connStr = ConfigurationManager.ConnectionStrings["strConn"].ConnectionString;
string SqlStr = "SELECT * from tblExpense_Project";
DataSet ds = new DataSet();
SqlConnection conn = new SqlConnection(connStr);
if (conn.State.ToString() == "Closed") conn.Open();
SqlDataAdapter da = new SqlDataAdapter(SqlStr, conn);
da.Fill(ds, "sProject");
if (conn.State.ToString() == "Open") conn.Close();
object aaaa = ds.Tables[0];
ddlsProject.DataSource = ds.Tables[0].DefaultView;
ddlsProject.DataTextField = "sProject";
ddlsProject.DataValueField = "iProjectId";
ddlsProject.DataBind();
//
// 选中 DropDownList
ddlsProject.SelectedValue = ((HiddenField)e.Row.FindControl("DDLsProject")).Value;
}
//页面代码
asp:TemplateField HeaderText="项目号">
<ItemTemplate>
<%# Eval("sProject")%>
</ItemTemplate>
<EditItemTemplate>
<asp:HiddenField ID="HDFsProject" runat="server" Value='<%# Eval("sProjectName") %>' />
<asp:DropDownList ID="DDLsProject" runat="server" Width="70px" />
</EditItemTemplate>
<ItemStyle Width="100px" />
</asp:TemplateField>这是已经写了的代码
DropDownList)e.Row.FindControl("DDLsProject")) 总是为空,所以进不去,
ddlsProject.DataSource = ds.Tables[0].DefaultView 也绑定不料。。说是对象未引用,,貌似为空。。。。希望大家帮帮忙。我第一次提问,所以我也没多少分,反正我有多少 就给多少。。。谢谢啦。。。 展开
if (((DropDownList)e.Row.FindControl("DDLsProject")) != null)
{
DropDownList ddlsProject = (DropDownList)e.Row.FindControl("DDLsProject");
// 生成 DropDownList 的值,绑定数据
string connStr = ConfigurationManager.ConnectionStrings["strConn"].ConnectionString;
string SqlStr = "SELECT * from tblExpense_Project";
DataSet ds = new DataSet();
SqlConnection conn = new SqlConnection(connStr);
if (conn.State.ToString() == "Closed") conn.Open();
SqlDataAdapter da = new SqlDataAdapter(SqlStr, conn);
da.Fill(ds, "sProject");
if (conn.State.ToString() == "Open") conn.Close();
object aaaa = ds.Tables[0];
ddlsProject.DataSource = ds.Tables[0].DefaultView;
ddlsProject.DataTextField = "sProject";
ddlsProject.DataValueField = "iProjectId";
ddlsProject.DataBind();
//
// 选中 DropDownList
ddlsProject.SelectedValue = ((HiddenField)e.Row.FindControl("DDLsProject")).Value;
}
//页面代码
asp:TemplateField HeaderText="项目号">
<ItemTemplate>
<%# Eval("sProject")%>
</ItemTemplate>
<EditItemTemplate>
<asp:HiddenField ID="HDFsProject" runat="server" Value='<%# Eval("sProjectName") %>' />
<asp:DropDownList ID="DDLsProject" runat="server" Width="70px" />
</EditItemTemplate>
<ItemStyle Width="100px" />
</asp:TemplateField>这是已经写了的代码
DropDownList)e.Row.FindControl("DDLsProject")) 总是为空,所以进不去,
ddlsProject.DataSource = ds.Tables[0].DefaultView 也绑定不料。。说是对象未引用,,貌似为空。。。。希望大家帮帮忙。我第一次提问,所以我也没多少分,反正我有多少 就给多少。。。谢谢啦。。。 展开
4个回答
展开全部
我之前也做过编辑状态下绑定下拉列表,在这里我有个建议,绑定下拉列表可以用可视化的方法编辑datasource即可,比这个简单多了。楼主可以试试。
还有就是DropDownList)e.Row.FindControl("DDLsProject"))它只有在编辑状态下,编辑列出现了下拉列表才不为空的,才会执行后面的代码。
希望帮到你。
还有就是DropDownList)e.Row.FindControl("DDLsProject"))它只有在编辑状态下,编辑列出现了下拉列表才不为空的,才会执行后面的代码。
希望帮到你。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
// 选中 DropDownList
ddlsProject.SelectedValue = ((HiddenField)e.Row.FindControl("DDLsProject")).Value;
上面的不要!
直接在ASPX中设置下拉列表属性selectedvalue=<%#Eval("selectedValue") %>,注意按空格键提示里没有该属性,但是能直接用,不知道当初微软为啥不显示该属性
ddlsProject.SelectedValue = ((HiddenField)e.Row.FindControl("DDLsProject")).Value;
上面的不要!
直接在ASPX中设置下拉列表属性selectedvalue=<%#Eval("selectedValue") %>,注意按空格键提示里没有该属性,但是能直接用,不知道当初微软为啥不显示该属性
追问
DropDownList)e.Row.FindControl("DDLsProject")) 总是空的,
所以 ddlsProject.SelectedValue = ((HiddenField)e.Row.FindControl("DDLsProject")).Value;
也是空的。。。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
<asp:DropDownList ID="DDLsProject" runat="server" Width="70px" />
少了点东西: DropDownList 是自动会发的控件
改成:
<asp:DropDownList ID="DDLsProject" runat="server" AutoPostBack="True" Width="70px"> </asp:DropDownList>
少了点东西: DropDownList 是自动会发的控件
改成:
<asp:DropDownList ID="DDLsProject" runat="server" AutoPostBack="True" Width="70px"> </asp:DropDownList>
追问
貌似还是不行。。。下拉列表,出来的时候,还是空的,要不我做个弹出页面算了。。
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
DropDownList ddlsProject = (DropDownList)e.Row.FindControl("DDLsProject");
ddlsProject.DataTextField = "sProject";
ddlsProject.DataValueField = "iProjectId";
ddlsProject.DataSource = ds.Tables[0].DefaultView;
ddlsProject.DataBind();
这么写试试
ddlsProject.DataTextField = "sProject";
ddlsProject.DataValueField = "iProjectId";
ddlsProject.DataSource = ds.Tables[0].DefaultView;
ddlsProject.DataBind();
这么写试试
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询