获取不到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);
}
}
}
...全文
148 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
  • 打赏
  • 举报
回复
如果觉得我表述不清 可以说一下 我解释
(题外话:从本次开始 我新增了jQuery EasyUI的专题页面 大家可以关注我的专题页来及时获取最新的EasyUI资源 专题页地址如下http:http://download.csdn.net/album/detail/343 同时也希望转载的那些朋友能保留我资源的说明及出处地址 我花那么多精力制作出来的 你们鼠标点两下就给我转走了还不注明出处 实在是不厚道 本来就是本着分享精神的 为的就是聚集一点人气和提供一个优良的环境来一起学习进步的 请不要抹杀掉我的热情 谢谢 )   时隔4个月之久 EasyUI终于迎来大版本更新了 本次更新内容诸多 除了常规维护外 还新增了3个新组件 都很实用 详细的可以阅读更新说明 面给了详细的解读 另外 从该版本开始我将会逐步的将EasyUI官方以及第三方较好的插件API整合到API文档当中 并且会对这些插件做一些简单的Demo实现 存放到配套提供的程序包demo文件夹下 以便大家学习和使用 本期文档中将官方提供的所有附加插件的API都整理并存放到Extension节点下了 这些扩展的demo在附带的程序包中已经提供 可以用于参考使用 jQuery EasyUI 1 4版本更新内容: Bug(修复) menu:修复在删除一个菜单项的时候该菜单无法正确自适应高度的问题; datagrid:修复在datagrid宽度太小的时候“fitColumns”方法无法正常工作的问题 Improvement(改进) EasyUI的所有组件已经支持非固定 百分比大小的尺寸设置; menu:添加“showItem” “hideItem”和“resize”方法; menu:基于窗体大小自动调整高度; menu:添加“duration”属性 该属性允许用户自定义隐藏菜单动画的持续时间 以毫秒为单位; validatebox:添加“onBeforeValidate”和“onValidate”事件; combo:从该版本开始combo组件扩展自textbox组件(textbox是1 4中新增的组件); combo:添加“panelMinWidth” “panelMaxWidth” “panelMinHeight”和“panelMaxHeight”属性; searchbox:从该版本开始searchbox组件扩展自textbox组件(textbox是1 4中新增的组件); tree:添加“getRoot”方法 用于返回通过“nodeEl”参数指定的节点的顶部父节点元素 注意:官网的英文API中该函数的说明有误 其说明是none 无参数 实际这是需要参数的 ; tree:添加“queryParams”属性; datetimebox:添加“spinnerWidth”属性; panel:添加“doLayout”方法 用于控制面板内组件的大小; panel:添加“clear”方法 用于清除面板内的内容; datagrid:允许用户设置百分比宽度的列(该功能真是千呼万唤始出来啊 ); form:添加“ajax” “novalidate”和“queryParams”属性; linkbutton:添加“resize”方法 New Plugin(新组件) textbox:该组件是一个增强的输入字段 它可以让用户非常简单的构建一个表单; datetimespinner:该组件是一个日期和时间的微调组件 它允许我们选择一个特定的日期或时间; filebox:filebox 该组件表单元素中用于上传文件的文件框工具组件 ">(题外话:从本次开始 我新增了jQuery EasyUI的专题页面 大家可以关注我的专题页来及时获取

62,269

社区成员

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

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

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

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