获取不到Grid View里TextBox的值 TextBox用模板添加的 'txtScore' ( 大侠快进)

zilong4460072 2008-12-11 11:25:23
后台代码如下: 先用DropDownList获得课程名称,在绑定Grid View数据,再Grid View里的TextBox输入成绩后点击 btnSubmit 来获取输入的成绩,但是就是显示不出来,也没提示错误,测试了btnSubmit里的语句,也没有错,不知道什么问题,大侠帮忙看看阿?
public partial class teacherSubmitScore : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
if (Session["userName"] == null )
{
Response.Redirect("Login.aspx");
}
if (!IsPostBack)
{
BindDDL();
}
BindGridView();
}
private void BindDDL()
{
string strconnection = ConfigurationManager.ConnectionStrings["zilong"].ConnectionString;
SqlConnection conn = new SqlConnection(strconnection);
string SqlStr = "select distinct Course.courseID,Course.courseName from Elect,Course where Elect.teaID=Course.teaID and Elect.teaID='" + Session["userName"].ToString() + "'"; //查询所教授的课程
DataSet ds = new DataSet();
conn.Open();
SqlDataAdapter da = new SqlDataAdapter(SqlStr, conn);
da.Fill(ds);
conn.Close();
ddl.DataSource = ds.Tables[0].DefaultView;
ddl.DataTextField = "courseName";
ddl.DataValueField = "courseID";
ddl.DataBind();
}
private void BindGridView()
{
string strconnection = ConfigurationManager.ConnectionStrings["zilong"].ConnectionString;
SqlConnection conn = new SqlConnection(strconnection);
GridView1.Visible = true;
string Sqlstr = "select * from Student,Elect where Student.stuID=Elect.stuID and Elect.courseID='" + ddl.SelectedValue + "'";
DataSet ds = new DataSet();
try
{
if (conn.State.ToString() == "Closed")
conn.Open();
SqlDataAdapter da = new SqlDataAdapter(Sqlstr, conn);
da.Fill(ds);
GridView1.DataSource = ds.Tables[0].DefaultView;
GridView1.DataBind();
}
catch{ }
finally
{ conn.Close();}
}
}
}
protected void btnSubmit_Click(object sender, EventArgs e)
{
for (int i = 0; i < GridView1.Rows.Count; i++)
{
string text = ((TextBox)GridView1.Rows[i].FindControl("txtScore")).Text.ToString;
Response.Write(text);
}
}
}
...全文
150 16 打赏 收藏 转发到动态 举报
写回复
用AI写文章
16 条回复
切换为时间正序
请发表友善的回复…
发表回复
quincystar 2008-12-11
  • 打赏
  • 举报
回复
楼主的意思是根据DropDownList里的值来绑定GridView ?
把DropDownList的AutoPostBack设为True试试.
rascalwm 2008-12-11
  • 打赏
  • 举报
回复
因为你要查找的是在模板里 然后 你直接去findControl 是查不到模板里的控件的 你得给他一个确切的位置 例如 this.gv.Rows[0].cells[0].findControl("id")
jiang_jiajia10 2008-12-11
  • 打赏
  • 举报
回复

protected void btnSubmit_Click(object sender, EventArgs e)
{
foreach (GridViewRow gr in GridView1.Rows)
{
TextBox text = (TextBox)gr.Cells[texbox所在列].FindControl("txtScore");
Response.Write(text);

}
}

ShadowInWind 2008-12-11
  • 打赏
  • 举报
回复
for (int i = 0; i < GridView1.Rows.Count; i++)
{
string text = ((TextBox)GridView1.Rows[i].FindControl("txtScore")).Text.ToString;
Response.Write(text);
}
toString是方法吧?这里当属性用的?
zilong4460072 2008-12-11
  • 打赏
  • 举报
回复
谢谢各位
成功解决问题!!
开始结贴
zilong4460072 2008-12-11
  • 打赏
  • 举报
回复
[Quote=引用 8 楼 wangping_li 的回复:]
foreach (GridViewRow gv in this.gridView.Rows)
{
string str= ((TextBox)gv.FindControl("Text的名称")).Text;
}
[/Quote]
可以解决输入成绩了
是把BindGirdView()放进
if (!IsPostBack)
{
BindDDL();
}
里边
但是可以输 出text的值了
Grid View就绑定不了DropDownList所选择的值了
xiaoyuzi 2008-12-11
  • 打赏
  • 举报
回复
测试了一下,没有问题啊,你可以先debug看能不能进去。
protected void Button3_Click(object sender, EventArgs e)
{
string strText = "";
for (int i = 0; i < this.GridView1.Rows.Count; i++)
{
strText += ((TextBox)(this.GridView1.Rows[i].FindControl("txtScore"))).Text;
}
Response.Write(strText);
}

gridview中的
<asp:BoundField DataField="Birthday" HeaderText="Birthday" SortExpression="Birthday" />
<asp:TemplateField>
<ItemTemplate>
<asp:TextBox ID="txtScore" runat="server"></asp:TextBox>
</ItemTemplate>
</asp:TemplateField>
criedshy 2008-12-11
  • 打赏
  • 举报
回复
DropDownList 'ddl' 用事件OnSelectedIndexChanged同时设置 AutoPostBack="true"

 protected void ddl_SelectedIndexChanged(object sender, EventArgs e)
{
BindGridView();
}
wangping_li 2008-12-11
  • 打赏
  • 举报
回复
foreach (GridViewRow gv in this.gridView.Rows)
{
string str= ((TextBox)gv.FindControl("Text的名称")).Text;
}
zilong4460072 2008-12-11
  • 打赏
  • 举报
回复
[Quote=引用 4 楼 criedshy 的回复:]
把BindGridView()方法放在(!IsPostBack) 里面就可以解决了
if (!IsPostBack)
{
BindDDL();
BindGridView();
}
[/Quote]

这样是可以输入text的值了
但是Grid View就绑定不了DropDownList所选择的值了
mengxj85 2008-12-11
  • 打赏
  • 举报
回复

//编辑
protected void btnSubmit_Click(object sender, EventArgs e)
{
foreach (GridViewRow gr in this.GridView1.Rows)
{
string text = ((TextBox)gr.FindControl("txtScore")).Text.ToString;
Response.Write(text);
}
}

贴了很多次
zilong4460072 2008-12-11
  • 打赏
  • 举报
回复
找到问题了
如果这样
if (!IsPostBack)
{
BindDDL();
BindGridView();
}
可以获得,输出text的值
但是下拉列表 DropDownList 'ddl' 选择课程名称的时候 Grid View就绑定不了了
怎么解决阿?
criedshy 2008-12-11
  • 打赏
  • 举报
回复
把BindGridView()方法放在(!IsPostBack) 里面就可以解决了
if (!IsPostBack)
{
BindDDL();
BindGridView();
}
zengxiongbin 2008-12-11
  • 打赏
  • 举报
回复
还有就是把BindGridView(); 放到if (!IsPostBack) 里面
zengxiongbin 2008-12-11
  • 打赏
  • 举报
回复

string text = "";
for (int i = 0; i < GridView1.Rows.Count; i++)
{
text += ((TextBox)GridView1.Rows[i].FindControl("txtScore")).Text.ToString;
}
Response.Write(text);

这样试试
zilong4460072 2008-12-11
  • 打赏
  • 举报
回复
如果觉得我表述不清 可以说一下 我解释

62,269

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧