2012-11-08 45 views
2

这似乎是一个常见的问题,但不知何故我发现的答案似乎没有解决我的情况 - 所以想知道我可能会失踪(我是新来的asp。所以请谅解任何明显的错误)。如何检索在asp.net gridview中的文本框的值

我有一个GridView绑定到一个ObjectDataSource,显示纸质杂志及其订阅价格。如果用户希望订阅任何杂志,我想为网格中的每一行添加一个文本框和一个按钮,以允许用户输入日期并单击该按钮进行订阅。 GridView中没有字段存在该文本框。

理想情况下,我想向UpdateParameters添加一个参数,以将文本框中的值发送到Update方法。但我一直没有成功。

我在使用FindControl时发现的一些建议也不起作用。 (我看到在Firefox中使用Inspect Element,生成的控件ID有一个Ctrl0,Ctrl1,Ctrl2前缀。

附加的是示例ASPX页面和代码隐藏在这里的任何见解

提前感谢

这里的ASPX文件,后面的代码:

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="TestGridView.aspx.cs" Inherits="WebApplication1.TestGridView" %> 

<!DOCTYPE html> 

<html xmlns="http://www.w3.org/1999/xhtml"> 
<head runat="server"> 
    <title></title> 
</head> 
<body> 
    <form id="form1" runat="server"> 
    <div> 
    <asp:GridView ID="GridView1" AutoGenerateColumns="false" runat="server" DatasourceID="ObjectDataSource2" DataKeyNames ="MagazineID" OnRowUpdating="GridView1_RowUpdating"> 
     <Columns> 
      <asp:BoundField DataField="MagazineID" HeaderText ="Magazine ID" ReadOnly="true" SortExpression="PricingID"> 
       <ControlStyle Width="100%" /> 
      </asp:BoundField> 
      <asp:BoundField DataField="MagazineName" HeaderText ="Magazine Name" ReadOnly="true" /> 
      <asp:BoundField DataField="MagazinePrice" HeaderText ="Magazine price" ReadOnly="true" /> 
      <asp:TemplateField HeaderText ="SubscriptionStartDate"> 
       <ItemTemplate> 
        <asp:TextBox ID ="txtSubscriptionStartDateStr" runat="server" Width ="100px"/> 
       </ItemTemplate> 
      </asp:TemplateField> 
      <asp:ButtonField ButtonType="Button" CommandName="Update" Text="Subscribe" /> 
     </Columns> 
    </asp:GridView> 

    <asp:ObjectDataSource ID="ObjectDataSource2" runat="server" UpdateMethod ="AddNewSubscription" SelectMethod="GetAllMagazines" TypeName="WebApplication1.TestGridView"> 
     <UpdateParameters> 
      <asp:ControlParameter ControlID="txtSubscriptionStartDateStr" DefaultValue="" Name="userName" PropertyName="Text" Type="string" /> 
     </UpdateParameters> 
    </asp:ObjectDataSource> 

    </div> 
    </form> 
</body> 
</html> 

代码隐藏:

using System; 
using System.Collections.Generic; 
using System.Data; 
using System.Linq; 
using System.Web; 
using System.Web.UI; 
using System.Web.UI.WebControls; 

namespace WebApplication1 
{ 
    public partial class TestGridView : System.Web.UI.Page 
    { 
     protected void Page_Load(object sender, EventArgs e) 
     { 

     } 

     public DataTable GetAllMagazines() 
     { 
      DataTable dt = new DataTable(); 

      object[] parms1 = new object[] {11, "Magazine1", 5.99}; 
      object[] parms2 = new object[] {12, "Magazine2", 3.99 }; 

      dt.Columns.Add("MagazineID"); 
      dt.Columns.Add("MagazineName"); 
      dt.Columns.Add("MagazinePrice"); 

      dt.Rows.Add(parms1); 
      dt.Rows.Add(parms2); 

      return dt; 
     } 

     protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e) 
     { 
      GridView gv = (GridView)sender; 
      GridViewRow gvRow = gv.Rows[e.RowIndex]; 
      TextBox tb = (TextBox) gv.FindControl("txtSubscriptionStartDateStr"); 
      if (tb == null) 
       throw new ApplicationException("Could not find TextBox"); 

      string subscriptionStartDateStr = tb.Text; 
      // more code to parse and use the subscription date 
     } 

     public void AddNewSubscription(int magazineID, string subscriptionStartDateStr) 
     { 
      // insert database row here. 

     } 
    } 
} 

回答

2

你几乎已经拥有它了,你正在对错误的对象调用FindControl。

在你GridView1_RowUpdating方法改变:

TextBox tb = (TextBox) gv.FindControl("txtSubscriptionStartDateStr"); 

TextBox tb = (TextBox) gvRow.FindControl("txtSubscriptionStartDateStr"); 

所以你的函数是这样的:

protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e) 
{ 
    GridView gv = (GridView)sender; 
    GridViewRow gvRow = gv.Rows[e.RowIndex]; 
    TextBox tb = (TextBox) gvRow.FindControl("txtSubscriptionStartDateStr"); 
    if (tb == null) 
    throw new ApplicationException("Could not find TextBox"); 

    string subscriptionStartDateStr = tb.Text; 
    // more code to parse and use the subscription date 
} 
+0

谢谢你的快速反应。这解决了它。 – user1809292

相关问题