在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 也绑定不料。。说是对象未引用,,貌似为空。。。。希望大家帮帮忙。我第一次提问,所以我也没多少分,反正我有多少 就给多少。。。谢谢啦。。。
展开
 我来答
zhuyanjie1124
2011-12-07
知道答主
回答量:8
采纳率:0%
帮助的人:3.9万
展开全部
我之前也做过编辑状态下绑定下拉列表,在这里我有个建议,绑定下拉列表可以用可视化的方法编辑datasource即可,比这个简单多了。楼主可以试试。
还有就是DropDownList)e.Row.FindControl("DDLsProject"))它只有在编辑状态下,编辑列出现了下拉列表才不为空的,才会执行后面的代码。
希望帮到你。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
班丘晓桐0U
2011-12-07 · TA获得超过446个赞
知道小有建树答主
回答量:739
采纳率:0%
帮助的人:620万
展开全部
// 选中 DropDownList
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;
也是空的。。。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
不想起名字了2333
2011-12-07 · TA获得超过2447个赞
知道大有可为答主
回答量:1931
采纳率:50%
帮助的人:1859万
展开全部
<asp:DropDownList ID="DDLsProject" runat="server" Width="70px" />
少了点东西: DropDownList 是自动会发的控件
改成:
<asp:DropDownList ID="DDLsProject" runat="server" AutoPostBack="True" Width="70px"> </asp:DropDownList>
追问
貌似还是不行。。。下拉列表,出来的时候,还是空的,要不我做个弹出页面算了。。
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友33452c2
2013-03-06
知道答主
回答量:5
采纳率:0%
帮助的人:2195
展开全部
DropDownList ddlsProject = (DropDownList)e.Row.FindControl("DDLsProject");

ddlsProject.DataTextField = "sProject";
ddlsProject.DataValueField = "iProjectId";

ddlsProject.DataSource = ds.Tables[0].DefaultView;

ddlsProject.DataBind();

这么写试试
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式